@flodesk/grain 11.32.1 → 11.33.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.
@@ -40,7 +40,7 @@ const ActionsSection = _ref2 => {
40
40
  children
41
41
  } = _ref2;
42
42
  return ___EmotionJSX(Arrange, {
43
- right: "fieldPaddingX",
43
+ right: "var(--grn-field-paddingX)",
44
44
  gap: "xs",
45
45
  position: "absolute",
46
46
  top: "0px",
@@ -15,7 +15,7 @@ import { Icon, Box, Arrange } from '.';
15
15
  import { IconChevronDown, IconPlus } from '../icons';
16
16
  import { Combobox } from '@headlessui/react';
17
17
  import { defaultProps, types } from '../types';
18
- import { InputField, MenuCard, MenuCardTransition, MenuGroupTitle, FieldLabel, FieldHint, componentVars, styles, FieldClearButton } from '../foundational';
18
+ import { InputField, MenuCard, MenuCardTransition, MenuGroupTitle, FieldLabel, FieldHint, styles, FieldClearButton } from '../foundational';
19
19
  import { MenuItemDivider, useMenuPosition } from '../foundational/menu';
20
20
  import { FloatingPortal } from '@floating-ui/react-dom-interactions';
21
21
  import { Global } from '@emotion/react';
@@ -33,7 +33,7 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
33
33
  hasError,
34
34
  isDisabled
35
35
  } = _ref;
36
- return !hasError && !isDisabled && "\n --borderColor: ".concat(getColor('fieldBorder'), ";\n &:hover { --borderColor: ").concat(getColor('fieldBorderHover'), " };\n &:focus-within { --borderColor: ").concat(getColor('fieldBorderFocus'), " };\n ");
36
+ return !hasError && !isDisabled && "\n --borderColor: var(--grn-field-border-color);\n &:hover { --borderColor: var(--grn-field-border-color-hover) };\n &:focus-within { --borderColor: var(--grn-field-border-color-focus) };\n ";
37
37
  }, ";", _ref2 => {
38
38
  let {
39
39
  hasError
@@ -54,13 +54,13 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
54
54
  let {
55
55
  isDisabled
56
56
  } = _ref5;
57
- return isDisabled && "\n --borderColor: ".concat(getColor('fieldBorderDisabled'), ";\n --backgroundColor: ").concat(getColor('fieldBackgroundDisabled'), ";\n\n * {\n pointer-events: none;\n }\n ");
57
+ return isDisabled && "\n --borderColor: var(--grn-field-border-color-disabled);\n --backgroundColor: var(--grn-field-background-disabled);\n\n * {\n pointer-events: none;\n }\n ";
58
58
  }, ";position:relative;margin-top:", _ref6 => {
59
59
  let {
60
60
  marginTop
61
61
  } = _ref6;
62
62
  return getSpace(marginTop);
63
- }, ";border-radius:", getRadius('s'), ";box-shadow:inset 0 0 0 ", componentVars.strokeSize, " var(--borderColor);background-color:var(--backgroundColor);.autocompleteInput{line-height:20px;border:none;opacity:", _ref7 => {
63
+ }, ";border-radius:", getRadius('s'), ";box-shadow:inset 0 0 0 var(--grn-border-size) var(--borderColor);background-color:var(--backgroundColor);.autocompleteInput{line-height:20px;border:none;opacity:", _ref7 => {
64
64
  let {
65
65
  open
66
66
  } = _ref7;
@@ -70,7 +70,7 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
70
70
  open
71
71
  } = _ref8;
72
72
  return open ? 'auto' : 'none';
73
- }, ";transition:opacity ", transitionSpeed, ";&:focus-visible,&:placeholder-shown{opacity:1;pointer-events:auto;transition:opacity ", transitionSpeed, ";}&:disabled:placeholder-shown{background:transparent;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAyBuB","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } 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  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst transitionSpeed = getTransition('xxFast');\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError, isDisabled }) =>\n    !hasError &&\n    !isDisabled &&\n    `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  ${({ hasError }) => hasError && `--borderColor: ${getColor('danger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: transparent;\n    `};\n\n  ${({ backgroundColor }) =>\n    backgroundColor &&\n    `\n      --backgroundColor: ${getColor(backgroundColor)};\n    `};\n\n  ${({ isDisabled }) =>\n    isDisabled &&\n    `\n      --borderColor: ${getColor('fieldBorderDisabled')};\n      --backgroundColor: ${getColor('fieldBackgroundDisabled')};\n\n      * {\n        pointer-events: none;\n      }\n    `};\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  background-color: var(--backgroundColor);\n\n  .autocompleteInput {\n    line-height: 20px;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${transitionSpeed};\n\n    &:focus-visible,\n    &:placeholder-shown {\n      opacity: 1;\n      pointer-events: auto;\n      transition: opacity ${transitionSpeed};\n    }\n    &:disabled:placeholder-shown {\n      background: transparent;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"fieldPaddingX\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\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 = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\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: var(--grn-textbox-height-m);\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 ${transitionSpeed};\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: 20px;\n  display: block;\n  padding-block: 0;\n  padding-left: ${getSpace('fieldPaddingX')};\n  padding-right: ${({ paddingRight }) => paddingRight};\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\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  isDisabled,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\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 newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  const chevronWidth = '12px';\n  const chevronGap = getSpace('s');\n  const paddingRightWithoutClear = `${getSpace('fieldPaddingX')} + ${chevronWidth} + ${chevronGap}`;\n  const inputPaddingRight = hasClearButton\n    ? `calc(${paddingRightWithoutClear} + ${componentVars.clearButtonHeight})`\n    : `calc(${paddingRightWithoutClear})`;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox\n        disabled={isDisabled}\n        as=\"div\"\n        value={selectedOption || ''}\n        onChange={handleChange}\n        {...props}\n      >\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\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n                isDisabled={isDisabled}\n              >\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={inputPaddingRight}\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\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}>\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                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\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  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\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  placeholder: PropTypes.string,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */"));
73
+ }, ";transition:opacity ", transitionSpeed, ";&:focus-visible,&:placeholder-shown{opacity:1;pointer-events:auto;transition:opacity ", transitionSpeed, ";}&:disabled:placeholder-shown{background:transparent;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAwBuB","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } 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  styles,\n  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst transitionSpeed = getTransition('xxFast');\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError, isDisabled }) =>\n    !hasError &&\n    !isDisabled &&\n    `\n      --borderColor: var(--grn-field-border-color);\n      &:hover { --borderColor: var(--grn-field-border-color-hover) };\n      &:focus-within { --borderColor: var(--grn-field-border-color-focus) };\n    `};\n\n  ${({ hasError }) => hasError && `--borderColor: ${getColor('danger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: transparent;\n    `};\n\n  ${({ backgroundColor }) =>\n    backgroundColor &&\n    `\n      --backgroundColor: ${getColor(backgroundColor)};\n    `};\n\n  ${({ isDisabled }) =>\n    isDisabled &&\n    `\n      --borderColor: var(--grn-field-border-color-disabled);\n      --backgroundColor: var(--grn-field-background-disabled);\n\n      * {\n        pointer-events: none;\n      }\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 var(--grn-border-size) var(--borderColor);\n  background-color: var(--backgroundColor);\n\n  .autocompleteInput {\n    line-height: 20px;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${transitionSpeed};\n\n    &:focus-visible,\n    &:placeholder-shown {\n      opacity: 1;\n      pointer-events: auto;\n      transition: opacity ${transitionSpeed};\n    }\n    &:disabled:placeholder-shown {\n      background: transparent;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"var(--grn-field-paddingX)\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\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 = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\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: var(--grn-textbox-height-m);\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 ${transitionSpeed};\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: 20px;\n  display: block;\n  padding-block: 0;\n  padding-left: var(--grn-field-paddingX);\n  padding-right: ${({ paddingRight }) => paddingRight};\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\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  isDisabled,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\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 newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  const chevronWidth = '12px';\n  const chevronGap = getSpace('s');\n  const paddingRightWithoutClear = `var(--grn-field-paddingX) + ${chevronWidth} + ${chevronGap}`;\n  const inputPaddingRight = hasClearButton\n    ? `calc(${paddingRightWithoutClear} + var(--grn-clearbutton-height))`\n    : `calc(${paddingRightWithoutClear})`;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox\n        disabled={isDisabled}\n        as=\"div\"\n        value={selectedOption || ''}\n        onChange={handleChange}\n        {...props}\n      >\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\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n                isDisabled={isDisabled}\n              >\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={inputPaddingRight}\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\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}>\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                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\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  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\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  placeholder: PropTypes.string,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */"));
74
74
 
75
75
  const EmptyState = () => ___EmotionJSX(Box, {
76
76
  paddingY: "s",
@@ -83,7 +83,7 @@ const ActionsSection = _ref9 => {
83
83
  children
84
84
  } = _ref9;
85
85
  return ___EmotionJSX(Arrange, {
86
- right: "fieldPaddingX",
86
+ right: "var(--grn-field-paddingX)",
87
87
  gap: "xs",
88
88
  position: "absolute",
89
89
  top: "0px",
@@ -154,19 +154,19 @@ const Trigger = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "product
154
154
  open
155
155
  } = _ref13;
156
156
  return open ? 'none' : 'auto';
157
- }, ";position:absolute;top:0;left:0;transition:opacity ", transitionSpeed, ";.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":"AAwM6B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } 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  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst transitionSpeed = getTransition('xxFast');\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError, isDisabled }) =>\n    !hasError &&\n    !isDisabled &&\n    `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  ${({ hasError }) => hasError && `--borderColor: ${getColor('danger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: transparent;\n    `};\n\n  ${({ backgroundColor }) =>\n    backgroundColor &&\n    `\n      --backgroundColor: ${getColor(backgroundColor)};\n    `};\n\n  ${({ isDisabled }) =>\n    isDisabled &&\n    `\n      --borderColor: ${getColor('fieldBorderDisabled')};\n      --backgroundColor: ${getColor('fieldBackgroundDisabled')};\n\n      * {\n        pointer-events: none;\n      }\n    `};\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  background-color: var(--backgroundColor);\n\n  .autocompleteInput {\n    line-height: 20px;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${transitionSpeed};\n\n    &:focus-visible,\n    &:placeholder-shown {\n      opacity: 1;\n      pointer-events: auto;\n      transition: opacity ${transitionSpeed};\n    }\n    &:disabled:placeholder-shown {\n      background: transparent;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"fieldPaddingX\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\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 = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\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: var(--grn-textbox-height-m);\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 ${transitionSpeed};\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: 20px;\n  display: block;\n  padding-block: 0;\n  padding-left: ${getSpace('fieldPaddingX')};\n  padding-right: ${({ paddingRight }) => paddingRight};\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\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  isDisabled,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\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 newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  const chevronWidth = '12px';\n  const chevronGap = getSpace('s');\n  const paddingRightWithoutClear = `${getSpace('fieldPaddingX')} + ${chevronWidth} + ${chevronGap}`;\n  const inputPaddingRight = hasClearButton\n    ? `calc(${paddingRightWithoutClear} + ${componentVars.clearButtonHeight})`\n    : `calc(${paddingRightWithoutClear})`;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox\n        disabled={isDisabled}\n        as=\"div\"\n        value={selectedOption || ''}\n        onChange={handleChange}\n        {...props}\n      >\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\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n                isDisabled={isDisabled}\n              >\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={inputPaddingRight}\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\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}>\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                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\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  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\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  placeholder: PropTypes.string,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */"));
157
+ }, ";position:absolute;top:0;left:0;transition:opacity ", transitionSpeed, ";.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":"AAuM6B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } 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  styles,\n  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst transitionSpeed = getTransition('xxFast');\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError, isDisabled }) =>\n    !hasError &&\n    !isDisabled &&\n    `\n      --borderColor: var(--grn-field-border-color);\n      &:hover { --borderColor: var(--grn-field-border-color-hover) };\n      &:focus-within { --borderColor: var(--grn-field-border-color-focus) };\n    `};\n\n  ${({ hasError }) => hasError && `--borderColor: ${getColor('danger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: transparent;\n    `};\n\n  ${({ backgroundColor }) =>\n    backgroundColor &&\n    `\n      --backgroundColor: ${getColor(backgroundColor)};\n    `};\n\n  ${({ isDisabled }) =>\n    isDisabled &&\n    `\n      --borderColor: var(--grn-field-border-color-disabled);\n      --backgroundColor: var(--grn-field-background-disabled);\n\n      * {\n        pointer-events: none;\n      }\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 var(--grn-border-size) var(--borderColor);\n  background-color: var(--backgroundColor);\n\n  .autocompleteInput {\n    line-height: 20px;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${transitionSpeed};\n\n    &:focus-visible,\n    &:placeholder-shown {\n      opacity: 1;\n      pointer-events: auto;\n      transition: opacity ${transitionSpeed};\n    }\n    &:disabled:placeholder-shown {\n      background: transparent;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"var(--grn-field-paddingX)\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\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 = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\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: var(--grn-textbox-height-m);\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 ${transitionSpeed};\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: 20px;\n  display: block;\n  padding-block: 0;\n  padding-left: var(--grn-field-paddingX);\n  padding-right: ${({ paddingRight }) => paddingRight};\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\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  isDisabled,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\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 newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  const chevronWidth = '12px';\n  const chevronGap = getSpace('s');\n  const paddingRightWithoutClear = `var(--grn-field-paddingX) + ${chevronWidth} + ${chevronGap}`;\n  const inputPaddingRight = hasClearButton\n    ? `calc(${paddingRightWithoutClear} + var(--grn-clearbutton-height))`\n    : `calc(${paddingRightWithoutClear})`;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox\n        disabled={isDisabled}\n        as=\"div\"\n        value={selectedOption || ''}\n        onChange={handleChange}\n        {...props}\n      >\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\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n                isDisabled={isDisabled}\n              >\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={inputPaddingRight}\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\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}>\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                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\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  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\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  placeholder: PropTypes.string,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */"));
158
158
 
159
159
  const TriggerText = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
160
160
  target: "ea1qwwn0"
161
161
  } : {
162
162
  target: "ea1qwwn0",
163
163
  label: "TriggerText"
164
- })("line-height:20px;display:block;padding-block:0;padding-left:", getSpace('fieldPaddingX'), ";padding-right:", _ref14 => {
164
+ })("line-height:20px;display:block;padding-block:0;padding-left:var(--grn-field-paddingX);padding-right:", _ref14 => {
165
165
  let {
166
166
  paddingRight
167
167
  } = _ref14;
168
168
  return paddingRight;
169
- }, ";text-overflow:ellipsis;overflow:hidden;white-space:nowrap;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAsO+B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } 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  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst transitionSpeed = getTransition('xxFast');\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError, isDisabled }) =>\n    !hasError &&\n    !isDisabled &&\n    `\n      --borderColor: ${getColor('fieldBorder')};\n      &:hover { --borderColor: ${getColor('fieldBorderHover')} };\n      &:focus-within { --borderColor: ${getColor('fieldBorderFocus')} };\n    `};\n\n  ${({ hasError }) => hasError && `--borderColor: ${getColor('danger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: transparent;\n    `};\n\n  ${({ backgroundColor }) =>\n    backgroundColor &&\n    `\n      --backgroundColor: ${getColor(backgroundColor)};\n    `};\n\n  ${({ isDisabled }) =>\n    isDisabled &&\n    `\n      --borderColor: ${getColor('fieldBorderDisabled')};\n      --backgroundColor: ${getColor('fieldBackgroundDisabled')};\n\n      * {\n        pointer-events: none;\n      }\n    `};\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  background-color: var(--backgroundColor);\n\n  .autocompleteInput {\n    line-height: 20px;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${transitionSpeed};\n\n    &:focus-visible,\n    &:placeholder-shown {\n      opacity: 1;\n      pointer-events: auto;\n      transition: opacity ${transitionSpeed};\n    }\n    &:disabled:placeholder-shown {\n      background: transparent;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"fieldPaddingX\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\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 = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\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: var(--grn-textbox-height-m);\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 ${transitionSpeed};\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: 20px;\n  display: block;\n  padding-block: 0;\n  padding-left: ${getSpace('fieldPaddingX')};\n  padding-right: ${({ paddingRight }) => paddingRight};\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\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  isDisabled,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\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 newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  const chevronWidth = '12px';\n  const chevronGap = getSpace('s');\n  const paddingRightWithoutClear = `${getSpace('fieldPaddingX')} + ${chevronWidth} + ${chevronGap}`;\n  const inputPaddingRight = hasClearButton\n    ? `calc(${paddingRightWithoutClear} + ${componentVars.clearButtonHeight})`\n    : `calc(${paddingRightWithoutClear})`;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox\n        disabled={isDisabled}\n        as=\"div\"\n        value={selectedOption || ''}\n        onChange={handleChange}\n        {...props}\n      >\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\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n                isDisabled={isDisabled}\n              >\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={inputPaddingRight}\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\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}>\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                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\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  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\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  placeholder: PropTypes.string,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */"));
169
+ }, ";text-overflow:ellipsis;overflow:hidden;white-space:nowrap;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAqO+B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange } from '.';\nimport { IconChevronDown, IconPlus } 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  styles,\n  FieldClearButton,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst transitionSpeed = getTransition('xxFast');\n\nconst Root = styled.div`\n  ${styles.transitions};\n  ${({ hasError, isDisabled }) =>\n    !hasError &&\n    !isDisabled &&\n    `\n      --borderColor: var(--grn-field-border-color);\n      &:hover { --borderColor: var(--grn-field-border-color-hover) };\n      &:focus-within { --borderColor: var(--grn-field-border-color-focus) };\n    `};\n\n  ${({ hasError }) => hasError && `--borderColor: ${getColor('danger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: transparent;\n    `};\n\n  ${({ backgroundColor }) =>\n    backgroundColor &&\n    `\n      --backgroundColor: ${getColor(backgroundColor)};\n    `};\n\n  ${({ isDisabled }) =>\n    isDisabled &&\n    `\n      --borderColor: var(--grn-field-border-color-disabled);\n      --backgroundColor: var(--grn-field-background-disabled);\n\n      * {\n        pointer-events: none;\n      }\n    `};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 var(--grn-border-size) var(--borderColor);\n  background-color: var(--backgroundColor);\n\n  .autocompleteInput {\n    line-height: 20px;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${transitionSpeed};\n\n    &:focus-visible,\n    &:placeholder-shown {\n      opacity: 1;\n      pointer-events: auto;\n      transition: opacity ${transitionSpeed};\n    }\n    &:disabled:placeholder-shown {\n      background: transparent;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\" color=\"content2\">\n    No results\n  </Box>\n);\n\nconst ActionsSection = ({ children }) => (\n  <Arrange\n    right=\"var(--grn-field-paddingX)\"\n    gap=\"xs\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} />;\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 = `\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: var(--grn-textbox-height-m);\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: var(--grn-textbox-height-m);\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 ${transitionSpeed};\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: 20px;\n  display: block;\n  padding-block: 0;\n  padding-left: var(--grn-field-paddingX);\n  padding-right: ${({ paddingRight }) => paddingRight};\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  isCreatable,\n  onCreate,\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  isDisabled,\n  searchField = 'content',\n  backgroundColor,\n  onClear,\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleCreatableChange = option => {\n    if (onCreate) {\n      const isCreatableOption = !options.find(item => item.value === option.value);\n      if (isCreatableOption) {\n        onCreate(option);\n        return;\n      }\n    }\n    onChange(option);\n  };\n\n  const handleChange = option => {\n    if (isCreatable) {\n      handleCreatableChange(option);\n    } else {\n      onChange(option);\n    }\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const isShowCreateOption = isCreatable && query.length > 0;\n\n  const noResults = !Boolean(filteredOptions.length) && !isShowCreateOption;\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 newOption = useMemo(() => ({ value: query, content: query }), [query]);\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  const hasClearButton = onClear && Boolean(selectedOption);\n\n  const chevronWidth = '12px';\n  const chevronGap = getSpace('s');\n  const paddingRightWithoutClear = `var(--grn-field-paddingX) + ${chevronWidth} + ${chevronGap}`;\n  const inputPaddingRight = hasClearButton\n    ? `calc(${paddingRightWithoutClear} + var(--grn-clearbutton-height))`\n    : `calc(${paddingRightWithoutClear})`;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox\n        disabled={isDisabled}\n        as=\"div\"\n        value={selectedOption || ''}\n        onChange={handleChange}\n        {...props}\n      >\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\n                marginTop={fieldMarginTop}\n                ref={reference}\n                open={open}\n                hasError={hasError}\n                backgroundColor={backgroundColor}\n                isDisabled={isDisabled}\n              >\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={inputPaddingRight}\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ActionsSection>\n                    {hasClearButton && <ClearButton onClick={onClear} />}\n                    <Icon icon={<IconChevronDown />} />\n                  </ActionsSection>\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition afterLeave={() => setQuery('')}>\n                    <Combobox.Options\n                      static\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\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}>\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                      {isShowCreateOption && (\n                        <>\n                          {filteredOptions.length > 0 && <MenuItemDivider />}\n                          <Combobox.Option value={newOption} as={Fragment}>\n                            {({ active }) => (\n                              <Item isActive={active} hasEllipsis={menuItemsHaveEllipsis}>\n                                <Arrange gap=\"s\" tag=\"span\">\n                                  <Icon icon={<IconPlus />} color={active ? 'content' : 'icon'} />\n                                  Create {`\"` + query + `\"`}\n                                </Arrange>\n                              </Item>\n                            )}\n                          </Combobox.Option>\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  isCreatable: PropTypes.bool,\n  onCreate: PropTypes.func,\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  placeholder: PropTypes.string,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n};\n"]} */"));
170
170
 
171
171
  export const Autocomplete2 = _ref15 => {
172
172
  let {
@@ -237,8 +237,8 @@ export const Autocomplete2 = _ref15 => {
237
237
  const hasClearButton = onClear && Boolean(selectedOption);
238
238
  const chevronWidth = '12px';
239
239
  const chevronGap = getSpace('s');
240
- const paddingRightWithoutClear = "".concat(getSpace('fieldPaddingX'), " + ").concat(chevronWidth, " + ").concat(chevronGap);
241
- const inputPaddingRight = hasClearButton ? "calc(".concat(paddingRightWithoutClear, " + ").concat(componentVars.clearButtonHeight, ")") : "calc(".concat(paddingRightWithoutClear, ")");
240
+ const paddingRightWithoutClear = "var(--grn-field-paddingX) + ".concat(chevronWidth, " + ").concat(chevronGap);
241
+ const inputPaddingRight = hasClearButton ? "calc(".concat(paddingRightWithoutClear, " + var(--grn-clearbutton-height))") : "calc(".concat(paddingRightWithoutClear, ")");
242
242
  return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
243
243
  styles: menuItemStyles
244
244
  }), ___EmotionJSX(Combobox, _extends({
@@ -15,7 +15,7 @@ import { getColor, getRadius, getSpace, getTransition } from '../utilities';
15
15
  import { Icon } from './icon';
16
16
  import React, { forwardRef } from 'react';
17
17
  import PropTypes from 'prop-types';
18
- import { styles, componentVars } from '../foundational';
18
+ import { styles } from '../foundational';
19
19
  import { Spinner } from './spinner';
20
20
  import { types } from '../types';
21
21
  import { Box } from './box';
@@ -61,7 +61,7 @@ const Wrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "product
61
61
  } : {
62
62
  target: "e1blxzk90",
63
63
  label: "Wrapper"
64
- })(styles.transitions, ";", styles.buttonReset, ";position:relative;border:none;border-width:", componentVars.strokeSize, ";border-style:solid;border-radius:", getRadius('s'), ";height:var(--grn-textbox-height-m);padding:0 ", getSpace('m'), ";background-color:transparent;display:flex;align-items:center;justify-content:center;gap:12px;", p => p.hasFullWidth && "width: 100%", ";", p => tagStyles[p.as], ";", _ref => {
64
+ })(styles.transitions, ";", styles.buttonReset, ";position:relative;border:none;border-width:var(--grn-border-size);border-style:solid;border-radius:", getRadius('s'), ";height:var(--grn-textbox-height-m);padding:0 ", getSpace('m'), ";background-color:transparent;display:flex;align-items:center;justify-content:center;gap:12px;", p => p.hasFullWidth && "width: 100%", ";", p => tagStyles[p.as], ";", _ref => {
65
65
  let {
66
66
  variant
67
67
  } = _ref;
@@ -71,7 +71,7 @@ const Wrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "product
71
71
  hasSpinner
72
72
  } = _ref2;
73
73
  return hasSpinner && "\n opacity: 0;\n transition: opacity ".concat(getTransition('fast'), ";\n ");
74
- }, ";}.buttonSpinner{animation:", fadeIn, " ", getTransition('slow'), ";}[data-experiment-rounded-button] &{border-radius:var(--grn-textbox-height-m);}[data-experiment-compact-textbox] &{padding:0 ", getSpace('s2'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2J1dHRvbi5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkQ2QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9idXR0b24uanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24gfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4vaWNvbic7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBzdHlsZXMsIGNvbXBvbmVudFZhcnMgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuaW1wb3J0IHsgU3Bpbm5lciB9IGZyb20gJy4vc3Bpbm5lcic7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IEJveCB9IGZyb20gJy4vYm94JztcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuL3RleHQnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5jb25zdCBpY29uSW52ZXJ0ID0gJ2hzbCh2YXIoLS1IUykgdmFyKC0tYmFja2dyb3VuZEwpIC8gdmFyKC0tZmFkZTEwLWEpKSc7XG5cbmNvbnN0IHZhcmlhbnRDb2xvcnMgPSB7XG4gIGFjY2VudDoge1xuICAgIGljb246IGljb25JbnZlcnQsXG4gICAgY29udGVudDogJ3NoYWRlMicsXG4gICAgYm9yZGVyOiAndHJhbnNwYXJlbnQnLFxuICAgIGJhY2tncm91bmQ6ICdzaGFkZTEyJyxcbiAgICBiYWNrZ3JvdW5kSG92ZXI6ICdzaGFkZTEwJyxcbiAgICBiYWNrZ3JvdW5kQWN0aXZlOiAnc2hhZGU5JyxcbiAgfSxcbiAgZGFuZ2VyOiB7XG4gICAgaWNvbjogJ2hzbCgwIDAlIDEwMCUgLyB2YXIoLS1mYWRlOC1hKSknLFxuICAgIGNvbnRlbnQ6ICd2YXIoLS13aGl0ZSknLFxuICAgIGJvcmRlcjogJ3RyYW5zcGFyZW50JyxcbiAgICBiYWNrZ3JvdW5kOiAnZGFuZ2VyJyxcbiAgICBiYWNrZ3JvdW5kSG92ZXI6ICdoc2wodmFyKC0tcmVkSFMpIGNhbGModmFyKC0tcmVkTCkgKyA0JSkpJyxcbiAgICBiYWNrZ3JvdW5kQWN0aXZlOiAnaHNsKHZhcigtLXJlZEhTKSBjYWxjKHZhcigtLXJlZEwpICsgNyUpKScsXG4gIH0sXG4gIG5ldXRyYWw6IHtcbiAgICBpY29uOiAnaWNvbicsXG4gICAgY29udGVudDogJ2NvbnRlbnQnLFxuICAgIGJvcmRlcjogJ2ZhZGU0JyxcbiAgICBib3JkZXJIb3ZlcjogJ2ZhZGU2JyxcbiAgICBib3JkZXJBY3RpdmU6ICdzaGFkZTgnLFxuICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gIH0sXG59O1xuXG5jb25zdCBmYWRlSW4gPSBrZXlmcmFtZXNgXG4gIDAlLCAyNSUgeyBvcGFjaXR5OiAwIH1cbmA7XG5cbmNvbnN0IHRhZ1N0eWxlcyA9IHtcbiAgYTogYFxuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG5cbiAgICAmOmhvdmVyIHtcbiAgICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgICB9XG4gIGAsXG4gIGJ1dHRvbjogYGAsXG4gIHNwYW46IGBcbiAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICBgLFxufTtcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgJHtzdHlsZXMuYnV0dG9uUmVzZXR9O1xuXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgYm9yZGVyOiBub25lO1xuICBib3JkZXItd2lkdGg6ICR7Y29tcG9uZW50VmFycy5zdHJva2VTaXplfTtcbiAgYm9yZGVyLXN0eWxlOiBzb2xpZDtcbiAgYm9yZGVyLXJhZGl1czogJHtnZXRSYWRpdXMoJ3MnKX07XG4gIGhlaWdodDogdmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LW0pO1xuICBwYWRkaW5nOiAwICR7Z2V0U3BhY2UoJ20nKX07XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgZ2FwOiAxMnB4O1xuICAke3AgPT4gcC5oYXNGdWxsV2lkdGggJiYgYHdpZHRoOiAxMDAlYH07XG4gICR7cCA9PiB0YWdTdHlsZXNbcC5hc119O1xuXG4gICR7KHsgdmFyaWFudCB9KSA9PiBgXG4gICAgLS1pY29uQ29sb3I6ICR7Z2V0Q29sb3IodmFyaWFudENvbG9yc1t2YXJpYW50XS5pY29uKX07XG4gICAgYm9yZGVyLWNvbG9yOiAke2dldENvbG9yKHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYm9yZGVyKX07XG4gICAgY29sb3I6ICR7Z2V0Q29sb3IodmFyaWFudENvbG9yc1t2YXJpYW50XS5jb250ZW50KX07XG4gICAgYmFja2dyb3VuZDogJHtnZXRDb2xvcih2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJhY2tncm91bmQpfTtcblxuICAgIEBtZWRpYShob3ZlcjogaG92ZXIpIHtcbiAgICAgICY6aG92ZXIge1xuICAgICAgICAtLWljb25Db2xvcjogY3VycmVudENvbG9yO1xuICAgICAgICAke1xuICAgICAgICAgIHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYmFja2dyb3VuZEhvdmVyICYmXG4gICAgICAgICAgYGJhY2tncm91bmQ6ICR7Z2V0Q29sb3IodmFyaWFudENvbG9yc1t2YXJpYW50XS5iYWNrZ3JvdW5kSG92ZXIpfWBcbiAgICAgICAgfTtcbiAgICAgICAgJHtcbiAgICAgICAgICB2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJvcmRlckhvdmVyICYmXG4gICAgICAgICAgYGJvcmRlci1jb2xvcjoke2dldENvbG9yKHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYm9yZGVySG92ZXIpfWBcbiAgICAgICAgfTtcblxuICAgICAgICAvLyBzZXQgY29sb3IgdG8gcHJldmVudCBpbmhlcml0aW5nIGZyb20gb3V0aXNkZSByZXNldFxuICAgICAgICBjb2xvcjogJHtnZXRDb2xvcih2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmNvbnRlbnQpfTtcbiAgICAgIH1cblxuICAgICAgJjphY3RpdmUge1xuICAgICAgICAke1xuICAgICAgICAgIHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYmFja2dyb3VuZEFjdGl2ZSAmJlxuICAgICAgICAgIGBiYWNrZ3JvdW5kOiAke2dldENvbG9yKHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYmFja2dyb3VuZEFjdGl2ZSl9YFxuICAgICAgICB9O1xuICAgICAgICAgJHtcbiAgICAgICAgICAgdmFyaWFudENvbG9yc1t2YXJpYW50XS5ib3JkZXJBY3RpdmUgJiZcbiAgICAgICAgICAgYGJvcmRlci1jb2xvcjoke2dldENvbG9yKHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYm9yZGVyQWN0aXZlKX1gXG4gICAgICAgICB9O1xuICAgICAgfVxuICAgIH1cbiAgYH1cblxuICAmOmRpc2FibGVkIHtcbiAgICAtLWljb25Db2xvcjogJHtnZXRDb2xvcignZGlzYWJsZWRJY29uJyl9O1xuICAgIGNvbG9yOiAke2dldENvbG9yKCdkaXNhYmxlZENvbnRlbnQnKX07XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRDb2xvcignZGlzYWJsZWRCYWNrZ3JvdW5kJyl9O1xuICAgIGJvcmRlci1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gIH1cblxuICAuSWNvbiB7XG4gICAgJHtwID0+IHAuaWNvblBvc2l0aW9uID09PSAncmlnaHQnICYmIGBvcmRlcjogMWB9O1xuICAgICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgfVxuXG4gIC5idXR0b25UZXh0LFxuICAuSWNvbiB7XG4gICAgJHsoeyBoYXNTcGlubmVyIH0pID0+XG4gICAgICBoYXNTcGlubmVyICYmXG4gICAgICBgXG4gICAgICBvcGFjaXR5OiAwO1xuICAgICAgdHJhbnNpdGlvbjogb3BhY2l0eSAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG4gICAgYH1cbiAgfVxuXG4gIC5idXR0b25TcGlubmVyIHtcbiAgICBhbmltYXRpb246ICR7ZmFkZUlufSAke2dldFRyYW5zaXRpb24oJ3Nsb3cnKX07XG4gIH1cblxuICBbZGF0YS1leHBlcmltZW50LXJvdW5kZWQtYnV0dG9uXSAmIHtcbiAgICBib3JkZXItcmFkaXVzOiB2YXIoLS1ncm4tdGV4dGJveC1oZWlnaHQtbSk7XG4gIH1cblxuICBbZGF0YS1leHBlcmltZW50LWNvbXBhY3QtdGV4dGJveF0gJiB7XG4gICAgcGFkZGluZzogMCAke2dldFNwYWNlKCdzMicpfTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IEJ1dHRvbiA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjaGlsZHJlbixcbiAgICAgIHZhcmlhbnQgPSAnbmV1dHJhbCcsXG4gICAgICBpc0Rpc2FibGVkLFxuICAgICAgaWNvbixcbiAgICAgIGljb25Qb3NpdGlvbiA9ICdsZWZ0JyxcbiAgICAgIGhhc0Z1bGxXaWR0aCxcbiAgICAgIGhhc1NwaW5uZXIsXG4gICAgICB0eXBlID0gJ2J1dHRvbicsXG4gICAgICB0YWcgPSAnYnV0dG9uJyxcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIHJldHVybiAoXG4gICAgICA8V3JhcHBlclxuICAgICAgICB0eXBlPXt0eXBlfVxuICAgICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgaWNvbj17aWNvbn1cbiAgICAgICAgaWNvblBvc2l0aW9uPXtpY29uUG9zaXRpb259XG4gICAgICAgIGhhc0Z1bGxXaWR0aD17aGFzRnVsbFdpZHRofVxuICAgICAgICBoYXNTcGlubmVyPXtoYXNTcGlubmVyfVxuICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgYXM9e3RhZ31cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7aGFzU3Bpbm5lciAmJiAoXG4gICAgICAgICAgPEJveCBwb3NpdGlvbj1cImFic29sdXRlXCIgY2xhc3NOYW1lPVwiYnV0dG9uU3Bpbm5lclwiPlxuICAgICAgICAgICAgPFNwaW5uZXIgY29sb3I9XCJjdXJyZW50Q29sb3JcIiAvPlxuICAgICAgICAgIDwvQm94PlxuICAgICAgICApfVxuICAgICAgICB7aWNvbiAmJiA8SWNvbiBpY29uPXtpY29ufSBjb2xvcj1cInZhcigtLWljb25Db2xvcilcIiAvPn1cbiAgICAgICAgPFRleHQgY2xhc3NOYW1lPVwiYnV0dG9uVGV4dFwiPntjaGlsZHJlbn08L1RleHQ+XG4gICAgICA8L1dyYXBwZXI+XG4gICAgKTtcbiAgfSxcbik7XG5cbkJ1dHRvbi5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaWNvbjogUHJvcFR5cGVzLm5vZGUsXG4gIGljb25Qb3NpdGlvbjogdHlwZXMuaWNvblBvc2l0aW9uLFxuICB2YXJpYW50OiB0eXBlcy5idXR0b25WYXJpYW50LFxuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGhhc0Z1bGxXaWR0aDogUHJvcFR5cGVzLmJvb2wsXG4gIGhhc1NwaW5uZXI6IFByb3BUeXBlcy5ib29sLFxuICB0eXBlOiB0eXBlcy5idXR0b25UeXBlLFxuICB0YWc6IHR5cGVzLmJ1dHRvblRhZyxcbn07XG4iXX0= */"));
74
+ }, ";}.buttonSpinner{animation:", fadeIn, " ", getTransition('slow'), ";}[data-experiment-rounded-button] &{border-radius:var(--grn-textbox-height-m);}[data-experiment-compact-textbox] &{padding:0 ", getSpace('s2'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2J1dHRvbi5qc3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkQ2QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9idXR0b24uanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24gfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4vaWNvbic7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuaW1wb3J0IHsgU3Bpbm5lciB9IGZyb20gJy4vc3Bpbm5lcic7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IEJveCB9IGZyb20gJy4vYm94JztcbmltcG9ydCB7IFRleHQgfSBmcm9tICcuL3RleHQnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5jb25zdCBpY29uSW52ZXJ0ID0gJ2hzbCh2YXIoLS1IUykgdmFyKC0tYmFja2dyb3VuZEwpIC8gdmFyKC0tZmFkZTEwLWEpKSc7XG5cbmNvbnN0IHZhcmlhbnRDb2xvcnMgPSB7XG4gIGFjY2VudDoge1xuICAgIGljb246IGljb25JbnZlcnQsXG4gICAgY29udGVudDogJ3NoYWRlMicsXG4gICAgYm9yZGVyOiAndHJhbnNwYXJlbnQnLFxuICAgIGJhY2tncm91bmQ6ICdzaGFkZTEyJyxcbiAgICBiYWNrZ3JvdW5kSG92ZXI6ICdzaGFkZTEwJyxcbiAgICBiYWNrZ3JvdW5kQWN0aXZlOiAnc2hhZGU5JyxcbiAgfSxcbiAgZGFuZ2VyOiB7XG4gICAgaWNvbjogJ2hzbCgwIDAlIDEwMCUgLyB2YXIoLS1mYWRlOC1hKSknLFxuICAgIGNvbnRlbnQ6ICd2YXIoLS13aGl0ZSknLFxuICAgIGJvcmRlcjogJ3RyYW5zcGFyZW50JyxcbiAgICBiYWNrZ3JvdW5kOiAnZGFuZ2VyJyxcbiAgICBiYWNrZ3JvdW5kSG92ZXI6ICdoc2wodmFyKC0tcmVkSFMpIGNhbGModmFyKC0tcmVkTCkgKyA0JSkpJyxcbiAgICBiYWNrZ3JvdW5kQWN0aXZlOiAnaHNsKHZhcigtLXJlZEhTKSBjYWxjKHZhcigtLXJlZEwpICsgNyUpKScsXG4gIH0sXG4gIG5ldXRyYWw6IHtcbiAgICBpY29uOiAnaWNvbicsXG4gICAgY29udGVudDogJ2NvbnRlbnQnLFxuICAgIGJvcmRlcjogJ2ZhZGU0JyxcbiAgICBib3JkZXJIb3ZlcjogJ2ZhZGU2JyxcbiAgICBib3JkZXJBY3RpdmU6ICdzaGFkZTgnLFxuICAgIGJhY2tncm91bmQ6ICd0cmFuc3BhcmVudCcsXG4gIH0sXG59O1xuXG5jb25zdCBmYWRlSW4gPSBrZXlmcmFtZXNgXG4gIDAlLCAyNSUgeyBvcGFjaXR5OiAwIH1cbmA7XG5cbmNvbnN0IHRhZ1N0eWxlcyA9IHtcbiAgYTogYFxuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG5cbiAgICAmOmhvdmVyIHtcbiAgICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgICB9XG4gIGAsXG4gIGJ1dHRvbjogYGAsXG4gIHNwYW46IGBcbiAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuICBgLFxufTtcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgJHtzdHlsZXMuYnV0dG9uUmVzZXR9O1xuXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgYm9yZGVyOiBub25lO1xuICBib3JkZXItd2lkdGg6IHZhcigtLWdybi1ib3JkZXItc2l6ZSk7XG4gIGJvcmRlci1zdHlsZTogc29saWQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdzJyl9O1xuICBoZWlnaHQ6IHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKTtcbiAgcGFkZGluZzogMCAke2dldFNwYWNlKCdtJyl9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGdhcDogMTJweDtcbiAgJHtwID0+IHAuaGFzRnVsbFdpZHRoICYmIGB3aWR0aDogMTAwJWB9O1xuICAke3AgPT4gdGFnU3R5bGVzW3AuYXNdfTtcblxuICAkeyh7IHZhcmlhbnQgfSkgPT4gYFxuICAgIC0taWNvbkNvbG9yOiAke2dldENvbG9yKHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uaWNvbil9O1xuICAgIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcih2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJvcmRlcil9O1xuICAgIGNvbG9yOiAke2dldENvbG9yKHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uY29udGVudCl9O1xuICAgIGJhY2tncm91bmQ6ICR7Z2V0Q29sb3IodmFyaWFudENvbG9yc1t2YXJpYW50XS5iYWNrZ3JvdW5kKX07XG5cbiAgICBAbWVkaWEoaG92ZXI6IGhvdmVyKSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgLS1pY29uQ29sb3I6IGN1cnJlbnRDb2xvcjtcbiAgICAgICAgJHtcbiAgICAgICAgICB2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJhY2tncm91bmRIb3ZlciAmJlxuICAgICAgICAgIGBiYWNrZ3JvdW5kOiAke2dldENvbG9yKHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYmFja2dyb3VuZEhvdmVyKX1gXG4gICAgICAgIH07XG4gICAgICAgICR7XG4gICAgICAgICAgdmFyaWFudENvbG9yc1t2YXJpYW50XS5ib3JkZXJIb3ZlciAmJlxuICAgICAgICAgIGBib3JkZXItY29sb3I6JHtnZXRDb2xvcih2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJvcmRlckhvdmVyKX1gXG4gICAgICAgIH07XG5cbiAgICAgICAgLy8gc2V0IGNvbG9yIHRvIHByZXZlbnQgaW5oZXJpdGluZyBmcm9tIG91dGlzZGUgcmVzZXRcbiAgICAgICAgY29sb3I6ICR7Z2V0Q29sb3IodmFyaWFudENvbG9yc1t2YXJpYW50XS5jb250ZW50KX07XG4gICAgICB9XG5cbiAgICAgICY6YWN0aXZlIHtcbiAgICAgICAgJHtcbiAgICAgICAgICB2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJhY2tncm91bmRBY3RpdmUgJiZcbiAgICAgICAgICBgYmFja2dyb3VuZDogJHtnZXRDb2xvcih2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJhY2tncm91bmRBY3RpdmUpfWBcbiAgICAgICAgfTtcbiAgICAgICAgICR7XG4gICAgICAgICAgIHZhcmlhbnRDb2xvcnNbdmFyaWFudF0uYm9yZGVyQWN0aXZlICYmXG4gICAgICAgICAgIGBib3JkZXItY29sb3I6JHtnZXRDb2xvcih2YXJpYW50Q29sb3JzW3ZhcmlhbnRdLmJvcmRlckFjdGl2ZSl9YFxuICAgICAgICAgfTtcbiAgICAgIH1cbiAgICB9XG4gIGB9XG5cbiAgJjpkaXNhYmxlZCB7XG4gICAgLS1pY29uQ29sb3I6ICR7Z2V0Q29sb3IoJ2Rpc2FibGVkSWNvbicpfTtcbiAgICBjb2xvcjogJHtnZXRDb2xvcignZGlzYWJsZWRDb250ZW50Jyl9O1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ2Rpc2FibGVkQmFja2dyb3VuZCcpfTtcbiAgICBib3JkZXItY29sb3I6IHRyYW5zcGFyZW50O1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5cbiAgLkljb24ge1xuICAgICR7cCA9PiBwLmljb25Qb3NpdGlvbiA9PT0gJ3JpZ2h0JyAmJiBgb3JkZXI6IDFgfTtcbiAgICAke3N0eWxlcy50cmFuc2l0aW9uc307XG4gIH1cblxuICAuYnV0dG9uVGV4dCxcbiAgLkljb24ge1xuICAgICR7KHsgaGFzU3Bpbm5lciB9KSA9PlxuICAgICAgaGFzU3Bpbm5lciAmJlxuICAgICAgYFxuICAgICAgb3BhY2l0eTogMDtcbiAgICAgIHRyYW5zaXRpb246IG9wYWNpdHkgJHtnZXRUcmFuc2l0aW9uKCdmYXN0Jyl9O1xuICAgIGB9XG4gIH1cblxuICAuYnV0dG9uU3Bpbm5lciB7XG4gICAgYW5pbWF0aW9uOiAke2ZhZGVJbn0gJHtnZXRUcmFuc2l0aW9uKCdzbG93Jyl9O1xuICB9XG5cbiAgW2RhdGEtZXhwZXJpbWVudC1yb3VuZGVkLWJ1dHRvbl0gJiB7XG4gICAgYm9yZGVyLXJhZGl1czogdmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LW0pO1xuICB9XG5cbiAgW2RhdGEtZXhwZXJpbWVudC1jb21wYWN0LXRleHRib3hdICYge1xuICAgIHBhZGRpbmc6IDAgJHtnZXRTcGFjZSgnczInKX07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBCdXR0b24gPSBmb3J3YXJkUmVmKFxuICAoXG4gICAge1xuICAgICAgY2hpbGRyZW4sXG4gICAgICB2YXJpYW50ID0gJ25ldXRyYWwnLFxuICAgICAgaXNEaXNhYmxlZCxcbiAgICAgIGljb24sXG4gICAgICBpY29uUG9zaXRpb24gPSAnbGVmdCcsXG4gICAgICBoYXNGdWxsV2lkdGgsXG4gICAgICBoYXNTcGlubmVyLFxuICAgICAgdHlwZSA9ICdidXR0b24nLFxuICAgICAgdGFnID0gJ2J1dHRvbicsXG4gICAgICAuLi5wcm9wc1xuICAgIH0sXG4gICAgcmVmLFxuICApID0+IHtcbiAgICByZXR1cm4gKFxuICAgICAgPFdyYXBwZXJcbiAgICAgICAgdHlwZT17dHlwZX1cbiAgICAgICAgdmFyaWFudD17dmFyaWFudH1cbiAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGljb249e2ljb259XG4gICAgICAgIGljb25Qb3NpdGlvbj17aWNvblBvc2l0aW9ufVxuICAgICAgICBoYXNGdWxsV2lkdGg9e2hhc0Z1bGxXaWR0aH1cbiAgICAgICAgaGFzU3Bpbm5lcj17aGFzU3Bpbm5lcn1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGFzPXt0YWd9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgID5cbiAgICAgICAge2hhc1NwaW5uZXIgJiYgKFxuICAgICAgICAgIDxCb3ggcG9zaXRpb249XCJhYnNvbHV0ZVwiIGNsYXNzTmFtZT1cImJ1dHRvblNwaW5uZXJcIj5cbiAgICAgICAgICAgIDxTcGlubmVyIGNvbG9yPVwiY3VycmVudENvbG9yXCIgLz5cbiAgICAgICAgICA8L0JveD5cbiAgICAgICAgKX1cbiAgICAgICAge2ljb24gJiYgPEljb24gaWNvbj17aWNvbn0gY29sb3I9XCJ2YXIoLS1pY29uQ29sb3IpXCIgLz59XG4gICAgICAgIDxUZXh0IGNsYXNzTmFtZT1cImJ1dHRvblRleHRcIj57Y2hpbGRyZW59PC9UZXh0PlxuICAgICAgPC9XcmFwcGVyPlxuICAgICk7XG4gIH0sXG4pO1xuXG5CdXR0b24ucHJvcFR5cGVzID0ge1xuICBjaGlsZHJlbjogUHJvcFR5cGVzLm5vZGUsXG4gIGljb246IFByb3BUeXBlcy5ub2RlLFxuICBpY29uUG9zaXRpb246IHR5cGVzLmljb25Qb3NpdGlvbixcbiAgdmFyaWFudDogdHlwZXMuYnV0dG9uVmFyaWFudCxcbiAgb25DbGljazogUHJvcFR5cGVzLmZ1bmMsXG4gIGlzRGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICBoYXNGdWxsV2lkdGg6IFByb3BUeXBlcy5ib29sLFxuICBoYXNTcGlubmVyOiBQcm9wVHlwZXMuYm9vbCxcbiAgdHlwZTogdHlwZXMuYnV0dG9uVHlwZSxcbiAgdGFnOiB0eXBlcy5idXR0b25UYWcsXG59O1xuIl19 */"));
75
75
 
76
76
  export const Button = /*#__PURE__*/forwardRef((_ref3, ref) => {
77
77
  let {
@@ -11,26 +11,25 @@ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) r
11
11
  import { getColor, getRadius, getSpace, getTransition } from '../utilities';
12
12
  import React from 'react';
13
13
  import PropTypes from 'prop-types';
14
- import { componentVars, FieldHint, FieldLabel } from '../foundational';
14
+ import { FieldHint, FieldLabel } from '../foundational';
15
15
  import { types } from '../types';
16
16
  import { jsx as ___EmotionJSX } from "@emotion/react";
17
17
  const size = 16;
18
18
  const checkHeight = size / 1.6;
19
19
  const checkWidth = checkHeight / 2;
20
20
  const checkStroke = 1.5;
21
- const strokeSize = componentVars.strokeSize;
22
21
 
23
22
  const CheckboxBoxInput = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "production" ? {
24
23
  target: "erxmy1h1"
25
24
  } : {
26
25
  target: "erxmy1h1",
27
26
  label: "CheckboxBoxInput"
28
- })("--checkColor:", getColor('shade2'), ";--backgroundColor:transparent;--backgroundColorActive:", getColor('shade12'), ";--borderColor:", getColor('shade6'), ";appearance:none;height:", size, "px;width:", size, "px;display:block;border-radius:", getRadius('xs'), ";cursor:pointer;margin:0;position:relative;background-color:var(--backgroundColor);border:", strokeSize, " solid var(--borderColor);transition:border-color ", getTransition('leave'), ";&:hover{--borderColor:", getColor('shade12'), ";transition:border-color ", getTransition('hover'), ";}&:checked{--borderColor:var(--backgroundColorActive);--backgroundColor:var(--backgroundColorActive);}&:before,&:after{content:'';position:absolute;background:var(--checkColor);display:block;transform:rotate(-45deg);transform-origin:bottom left;pointer-events:none;opacity:0;border-radius:", checkStroke, "px;left:", (size - checkWidth) / 2, "px;bottom:", (size - checkHeight) / 2, "px;}&:before{width:", checkStroke, "px;height:", checkWidth, "px;}&:after{width:", checkHeight, "px;height:", checkStroke, "px;}&:checked:before,&:checked:after{opacity:1;}", _ref => {
27
+ })("--checkColor:", getColor('shade2'), ";--backgroundColor:transparent;--backgroundColorActive:", getColor('shade12'), ";--borderColor:", getColor('shade6'), ";appearance:none;height:", size, "px;width:", size, "px;display:block;border-radius:", getRadius('xs'), ";cursor:pointer;margin:0;position:relative;background-color:var(--backgroundColor);border:var(--grn-border-size) solid var(--borderColor);transition:border-color ", getTransition('leave'), ";&:hover{--borderColor:", getColor('shade12'), ";transition:border-color ", getTransition('hover'), ";}&:checked{--borderColor:var(--backgroundColorActive);--backgroundColor:var(--backgroundColorActive);}&:before,&:after{content:'';position:absolute;background:var(--checkColor);display:block;transform:rotate(-45deg);transform-origin:bottom left;pointer-events:none;opacity:0;border-radius:", checkStroke, "px;left:", (size - checkWidth) / 2, "px;bottom:", (size - checkHeight) / 2, "px;}&:before{width:", checkStroke, "px;height:", checkWidth, "px;}&:after{width:", checkHeight, "px;height:", checkStroke, "px;}&:checked:before,&:checked:after{opacity:1;}", _ref => {
29
28
  let {
30
29
  isIndeterminate
31
30
  } = _ref;
32
31
  return isIndeterminate && "\n &:not(:checked) {\n --borderColor: var(--backgroundColorActive);\n --backgroundColor: var(--backgroundColorActive);\n\n &:before {\n content: unset;\n }\n &:after {\n transform: rotate(0deg);\n left: 0;\n right: 0;\n top: 0;\n bottom: 0;\n margin: auto;\n opacity: 1;\n }\n }\n ";
33
- }, " &:disabled{--checkColor:", getColor('disabledContent'), ";--backgroundColor:", getColor('disabledBackground'), ";--backgroundColorActive:", getColor('disabledBackground'), ";--borderColor:transparent;pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2NoZWNrYm94LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjcUMiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvY2hlY2tib3guanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24gfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBjb21wb25lbnRWYXJzLCBGaWVsZEhpbnQsIEZpZWxkTGFiZWwgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmNvbnN0IHNpemUgPSAxNjtcbmNvbnN0IGNoZWNrSGVpZ2h0ID0gc2l6ZSAvIDEuNjtcbmNvbnN0IGNoZWNrV2lkdGggPSBjaGVja0hlaWdodCAvIDI7XG5jb25zdCBjaGVja1N0cm9rZSA9IDEuNTtcblxuY29uc3Qgc3Ryb2tlU2l6ZSA9IGNvbXBvbmVudFZhcnMuc3Ryb2tlU2l6ZTtcblxuY29uc3QgQ2hlY2tib3hCb3hJbnB1dCA9IHN0eWxlZC5pbnB1dGBcbiAgLS1jaGVja0NvbG9yOiAke2dldENvbG9yKCdzaGFkZTInKX07XG4gIC0tYmFja2dyb3VuZENvbG9yOiB0cmFuc3BhcmVudDtcbiAgLS1iYWNrZ3JvdW5kQ29sb3JBY3RpdmU6ICR7Z2V0Q29sb3IoJ3NoYWRlMTInKX07XG4gIC0tYm9yZGVyQ29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlNicpfTtcblxuICBhcHBlYXJhbmNlOiBub25lO1xuICBoZWlnaHQ6ICR7c2l6ZX1weDtcbiAgd2lkdGg6ICR7c2l6ZX1weDtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCd4cycpfTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBtYXJnaW46IDA7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yKTtcbiAgYm9yZGVyOiAke3N0cm9rZVNpemV9IHNvbGlkIHZhcigtLWJvcmRlckNvbG9yKTtcbiAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7Z2V0VHJhbnNpdGlvbignbGVhdmUnKX07XG5cbiAgJjpob3ZlciB7XG4gICAgLS1ib3JkZXJDb2xvcjogJHtnZXRDb2xvcignc2hhZGUxMicpfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtnZXRUcmFuc2l0aW9uKCdob3ZlcicpfTtcbiAgfVxuXG4gICY6Y2hlY2tlZCB7XG4gICAgLS1ib3JkZXJDb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yQWN0aXZlKTtcbiAgICAtLWJhY2tncm91bmRDb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yQWN0aXZlKTtcbiAgfVxuXG4gICY6YmVmb3JlLFxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgYmFja2dyb3VuZDogdmFyKC0tY2hlY2tDb2xvcik7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgdHJhbnNmb3JtOiByb3RhdGUoLTQ1ZGVnKTtcbiAgICB0cmFuc2Zvcm0tb3JpZ2luOiBib3R0b20gbGVmdDtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICBvcGFjaXR5OiAwO1xuICAgIGJvcmRlci1yYWRpdXM6ICR7Y2hlY2tTdHJva2V9cHg7XG4gICAgbGVmdDogJHsoc2l6ZSAtIGNoZWNrV2lkdGgpIC8gMn1weDtcbiAgICBib3R0b206ICR7KHNpemUgLSBjaGVja0hlaWdodCkgLyAyfXB4O1xuICB9XG5cbiAgJjpiZWZvcmUge1xuICAgIHdpZHRoOiAke2NoZWNrU3Ryb2tlfXB4O1xuICAgIGhlaWdodDogJHtjaGVja1dpZHRofXB4O1xuICB9XG5cbiAgJjphZnRlciB7XG4gICAgd2lkdGg6ICR7Y2hlY2tIZWlnaHR9cHg7XG4gICAgaGVpZ2h0OiAke2NoZWNrU3Ryb2tlfXB4O1xuICB9XG5cbiAgJjpjaGVja2VkOmJlZm9yZSxcbiAgJjpjaGVja2VkOmFmdGVyIHtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5cbiAgJHsoeyBpc0luZGV0ZXJtaW5hdGUgfSkgPT5cbiAgICBpc0luZGV0ZXJtaW5hdGUgJiZcbiAgICBgXG4gICAgJjpub3QoOmNoZWNrZWQpIHtcbiAgICAgIC0tYm9yZGVyQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG4gICAgICAtLWJhY2tncm91bmRDb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yQWN0aXZlKTtcblxuICAgICAgJjpiZWZvcmUge1xuICAgICAgICBjb250ZW50OiB1bnNldDtcbiAgICAgIH1cbiAgICAgICY6YWZ0ZXIge1xuICAgICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwZGVnKTtcbiAgICAgICAgbGVmdDogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHRvcDogMDtcbiAgICAgICAgYm90dG9tOiAwO1xuICAgICAgICBtYXJnaW46IGF1dG87XG4gICAgICAgIG9wYWNpdHk6IDE7XG4gICAgICB9XG4gICAgfVxuICBgfVxuXG4gICY6ZGlzYWJsZWQge1xuICAgIC0tY2hlY2tDb2xvcjogJHtnZXRDb2xvcignZGlzYWJsZWRDb250ZW50Jyl9O1xuICAgIC0tYmFja2dyb3VuZENvbG9yOiAke2dldENvbG9yKCdkaXNhYmxlZEJhY2tncm91bmQnKX07XG4gICAgLS1iYWNrZ3JvdW5kQ29sb3JBY3RpdmU6ICR7Z2V0Q29sb3IoJ2Rpc2FibGVkQmFja2dyb3VuZCcpfTtcbiAgICAtLWJvcmRlckNvbG9yOiB0cmFuc3BhcmVudDtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgfVxuYDtcblxuY29uc3QgQ2hlY2tib3hCb3ggPSAoeyBvbkNoYW5nZSA9ICgpID0+IHt9LCAuLi5wcm9wcyB9KSA9PiAoXG4gIDxDaGVja2JveEJveElucHV0IHsuLi5wcm9wc30gb25DaGFuZ2U9e29uQ2hhbmdlfSB0eXBlPVwiY2hlY2tib3hcIiAvPlxuKTtcblxuY29uc3QgUm9vdCA9IHN0eWxlZC5kaXZgXG4gICR7KHsgaGFzVGV4dCB9KSA9PlxuICAgIGhhc1RleHQgJiZcbiAgICBgXG4gICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgZ3JpZC1hdXRvLWZsb3c6IGNvbHVtbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICBjb2x1bW4tZ2FwOiAke2dldFNwYWNlKCdiZXR3ZWVuRm9ybUNvbnRyb2xBbmRMYWJlbCcpfTtcbiAgICBgfVxuXG4gIC5jaGVja2JveEhpbnQsIC5jaGVja2JveExhYmVsIHtcbiAgICBncmlkLWNvbHVtbjogMiAvIDM7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDaGVja2JveCA9ICh7XG4gIGlzRGlzYWJsZWQsXG4gIGlzQ2hlY2tlZCxcbiAgaXNJbmRldGVybWluYXRlLFxuICBsYWJlbCxcbiAgaGludCxcbiAgaWQsXG4gIG9uQ2hhbmdlLFxuICAuLi5wcm9wc1xufSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxSb290IGhhc1RleHQ9e2xhYmVsIHx8IGhpbnR9IHsuLi5wcm9wc30+XG4gICAgICA8Q2hlY2tib3hCb3hcbiAgICAgICAgdHlwZT1cImNoZWNrYm94XCJcbiAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGlkPXtpZH1cbiAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17aXNJbmRldGVybWluYXRlfVxuICAgICAgLz5cbiAgICAgIHtsYWJlbCAmJiAoXG4gICAgICAgIDxGaWVsZExhYmVsIGh0bWxGb3I9e2lkfSBjbGFzc05hbWU9XCJjaGVja2JveExhYmVsXCI+XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L0ZpZWxkTGFiZWw+XG4gICAgICApfVxuICAgICAge2hpbnQgJiYgPEZpZWxkSGludCBjbGFzc05hbWU9XCJjaGVja2JveEhpbnRcIj57aGludH08L0ZpZWxkSGludD59XG4gICAgPC9Sb290PlxuICApO1xufTtcblxuQ2hlY2tib3guTGFiZWwgPSBGaWVsZExhYmVsO1xuQ2hlY2tib3guQm94ID0gQ2hlY2tib3hCb3g7XG5cbkNoZWNrYm94LnByb3BUeXBlcyA9IHtcbiAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgb25DaGFuZ2U6IFByb3BUeXBlcy5mdW5jLFxuICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNDaGVja2VkOiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNJbmRldGVybWluYXRlOiBQcm9wVHlwZXMuYm9vbCxcbiAgbGFiZWw6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGhpbnQ6IHR5cGVzLmhpbnQsXG59O1xuIl19 */"));
32
+ }, " &:disabled{--checkColor:", getColor('disabledContent'), ";--backgroundColor:", getColor('disabledBackground'), ";--backgroundColorActive:", getColor('disabledBackground'), ";--borderColor:transparent;pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2NoZWNrYm94LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZcUMiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvY2hlY2tib3guanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24gfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBGaWVsZEhpbnQsIEZpZWxkTGFiZWwgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmNvbnN0IHNpemUgPSAxNjtcbmNvbnN0IGNoZWNrSGVpZ2h0ID0gc2l6ZSAvIDEuNjtcbmNvbnN0IGNoZWNrV2lkdGggPSBjaGVja0hlaWdodCAvIDI7XG5jb25zdCBjaGVja1N0cm9rZSA9IDEuNTtcblxuY29uc3QgQ2hlY2tib3hCb3hJbnB1dCA9IHN0eWxlZC5pbnB1dGBcbiAgLS1jaGVja0NvbG9yOiAke2dldENvbG9yKCdzaGFkZTInKX07XG4gIC0tYmFja2dyb3VuZENvbG9yOiB0cmFuc3BhcmVudDtcbiAgLS1iYWNrZ3JvdW5kQ29sb3JBY3RpdmU6ICR7Z2V0Q29sb3IoJ3NoYWRlMTInKX07XG4gIC0tYm9yZGVyQ29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlNicpfTtcblxuICBhcHBlYXJhbmNlOiBub25lO1xuICBoZWlnaHQ6ICR7c2l6ZX1weDtcbiAgd2lkdGg6ICR7c2l6ZX1weDtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCd4cycpfTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBtYXJnaW46IDA7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yKTtcbiAgYm9yZGVyOiB2YXIoLS1ncm4tYm9yZGVyLXNpemUpIHNvbGlkIHZhcigtLWJvcmRlckNvbG9yKTtcbiAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7Z2V0VHJhbnNpdGlvbignbGVhdmUnKX07XG5cbiAgJjpob3ZlciB7XG4gICAgLS1ib3JkZXJDb2xvcjogJHtnZXRDb2xvcignc2hhZGUxMicpfTtcbiAgICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtnZXRUcmFuc2l0aW9uKCdob3ZlcicpfTtcbiAgfVxuXG4gICY6Y2hlY2tlZCB7XG4gICAgLS1ib3JkZXJDb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yQWN0aXZlKTtcbiAgICAtLWJhY2tncm91bmRDb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yQWN0aXZlKTtcbiAgfVxuXG4gICY6YmVmb3JlLFxuICAmOmFmdGVyIHtcbiAgICBjb250ZW50OiAnJztcbiAgICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gICAgYmFja2dyb3VuZDogdmFyKC0tY2hlY2tDb2xvcik7XG4gICAgZGlzcGxheTogYmxvY2s7XG4gICAgdHJhbnNmb3JtOiByb3RhdGUoLTQ1ZGVnKTtcbiAgICB0cmFuc2Zvcm0tb3JpZ2luOiBib3R0b20gbGVmdDtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICBvcGFjaXR5OiAwO1xuICAgIGJvcmRlci1yYWRpdXM6ICR7Y2hlY2tTdHJva2V9cHg7XG4gICAgbGVmdDogJHsoc2l6ZSAtIGNoZWNrV2lkdGgpIC8gMn1weDtcbiAgICBib3R0b206ICR7KHNpemUgLSBjaGVja0hlaWdodCkgLyAyfXB4O1xuICB9XG5cbiAgJjpiZWZvcmUge1xuICAgIHdpZHRoOiAke2NoZWNrU3Ryb2tlfXB4O1xuICAgIGhlaWdodDogJHtjaGVja1dpZHRofXB4O1xuICB9XG5cbiAgJjphZnRlciB7XG4gICAgd2lkdGg6ICR7Y2hlY2tIZWlnaHR9cHg7XG4gICAgaGVpZ2h0OiAke2NoZWNrU3Ryb2tlfXB4O1xuICB9XG5cbiAgJjpjaGVja2VkOmJlZm9yZSxcbiAgJjpjaGVja2VkOmFmdGVyIHtcbiAgICBvcGFjaXR5OiAxO1xuICB9XG5cbiAgJHsoeyBpc0luZGV0ZXJtaW5hdGUgfSkgPT5cbiAgICBpc0luZGV0ZXJtaW5hdGUgJiZcbiAgICBgXG4gICAgJjpub3QoOmNoZWNrZWQpIHtcbiAgICAgIC0tYm9yZGVyQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG4gICAgICAtLWJhY2tncm91bmRDb2xvcjogdmFyKC0tYmFja2dyb3VuZENvbG9yQWN0aXZlKTtcblxuICAgICAgJjpiZWZvcmUge1xuICAgICAgICBjb250ZW50OiB1bnNldDtcbiAgICAgIH1cbiAgICAgICY6YWZ0ZXIge1xuICAgICAgICB0cmFuc2Zvcm06IHJvdGF0ZSgwZGVnKTtcbiAgICAgICAgbGVmdDogMDtcbiAgICAgICAgcmlnaHQ6IDA7XG4gICAgICAgIHRvcDogMDtcbiAgICAgICAgYm90dG9tOiAwO1xuICAgICAgICBtYXJnaW46IGF1dG87XG4gICAgICAgIG9wYWNpdHk6IDE7XG4gICAgICB9XG4gICAgfVxuICBgfVxuXG4gICY6ZGlzYWJsZWQge1xuICAgIC0tY2hlY2tDb2xvcjogJHtnZXRDb2xvcignZGlzYWJsZWRDb250ZW50Jyl9O1xuICAgIC0tYmFja2dyb3VuZENvbG9yOiAke2dldENvbG9yKCdkaXNhYmxlZEJhY2tncm91bmQnKX07XG4gICAgLS1iYWNrZ3JvdW5kQ29sb3JBY3RpdmU6ICR7Z2V0Q29sb3IoJ2Rpc2FibGVkQmFja2dyb3VuZCcpfTtcbiAgICAtLWJvcmRlckNvbG9yOiB0cmFuc3BhcmVudDtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgfVxuYDtcblxuY29uc3QgQ2hlY2tib3hCb3ggPSAoeyBvbkNoYW5nZSA9ICgpID0+IHt9LCAuLi5wcm9wcyB9KSA9PiAoXG4gIDxDaGVja2JveEJveElucHV0IHsuLi5wcm9wc30gb25DaGFuZ2U9e29uQ2hhbmdlfSB0eXBlPVwiY2hlY2tib3hcIiAvPlxuKTtcblxuY29uc3QgUm9vdCA9IHN0eWxlZC5kaXZgXG4gICR7KHsgaGFzVGV4dCB9KSA9PlxuICAgIGhhc1RleHQgJiZcbiAgICBgXG4gICAgICBkaXNwbGF5OiBncmlkO1xuICAgICAgZ3JpZC1hdXRvLWZsb3c6IGNvbHVtbjtcbiAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gICAgICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gICAgICBjb2x1bW4tZ2FwOiAke2dldFNwYWNlKCdiZXR3ZWVuRm9ybUNvbnRyb2xBbmRMYWJlbCcpfTtcbiAgICBgfVxuXG4gIC5jaGVja2JveEhpbnQsIC5jaGVja2JveExhYmVsIHtcbiAgICBncmlkLWNvbHVtbjogMiAvIDM7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBDaGVja2JveCA9ICh7XG4gIGlzRGlzYWJsZWQsXG4gIGlzQ2hlY2tlZCxcbiAgaXNJbmRldGVybWluYXRlLFxuICBsYWJlbCxcbiAgaGludCxcbiAgaWQsXG4gIG9uQ2hhbmdlLFxuICAuLi5wcm9wc1xufSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxSb290IGhhc1RleHQ9e2xhYmVsIHx8IGhpbnR9IHsuLi5wcm9wc30+XG4gICAgICA8Q2hlY2tib3hCb3hcbiAgICAgICAgdHlwZT1cImNoZWNrYm94XCJcbiAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGlkPXtpZH1cbiAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICAgIGlzSW5kZXRlcm1pbmF0ZT17aXNJbmRldGVybWluYXRlfVxuICAgICAgLz5cbiAgICAgIHtsYWJlbCAmJiAoXG4gICAgICAgIDxGaWVsZExhYmVsIGh0bWxGb3I9e2lkfSBjbGFzc05hbWU9XCJjaGVja2JveExhYmVsXCI+XG4gICAgICAgICAge2xhYmVsfVxuICAgICAgICA8L0ZpZWxkTGFiZWw+XG4gICAgICApfVxuICAgICAge2hpbnQgJiYgPEZpZWxkSGludCBjbGFzc05hbWU9XCJjaGVja2JveEhpbnRcIj57aGludH08L0ZpZWxkSGludD59XG4gICAgPC9Sb290PlxuICApO1xufTtcblxuQ2hlY2tib3guTGFiZWwgPSBGaWVsZExhYmVsO1xuQ2hlY2tib3guQm94ID0gQ2hlY2tib3hCb3g7XG5cbkNoZWNrYm94LnByb3BUeXBlcyA9IHtcbiAgaWQ6IFByb3BUeXBlcy5zdHJpbmcuaXNSZXF1aXJlZCxcbiAgb25DaGFuZ2U6IFByb3BUeXBlcy5mdW5jLFxuICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNDaGVja2VkOiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNJbmRldGVybWluYXRlOiBQcm9wVHlwZXMuYm9vbCxcbiAgbGFiZWw6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGhpbnQ6IHR5cGVzLmhpbnQsXG59O1xuIl19 */"));
34
33
 
35
34
  const CheckboxBox = _ref2 => {
36
35
  let {
@@ -54,7 +53,7 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
54
53
  hasText
55
54
  } = _ref3;
56
55
  return hasText && "\n display: grid;\n grid-auto-flow: column;\n align-items: center;\n width: fit-content;\n column-gap: ".concat(getSpace('betweenFormControlAndLabel'), ";\n ");
57
- }, " .checkboxHint,.checkboxLabel{grid-column:2/3;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2NoZWNrYm94LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyR3VCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2NoZWNrYm94LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldENvbG9yLCBnZXRSYWRpdXMsIGdldFNwYWNlLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgY29tcG9uZW50VmFycywgRmllbGRIaW50LCBGaWVsZExhYmVsIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBzaXplID0gMTY7XG5jb25zdCBjaGVja0hlaWdodCA9IHNpemUgLyAxLjY7XG5jb25zdCBjaGVja1dpZHRoID0gY2hlY2tIZWlnaHQgLyAyO1xuY29uc3QgY2hlY2tTdHJva2UgPSAxLjU7XG5cbmNvbnN0IHN0cm9rZVNpemUgPSBjb21wb25lbnRWYXJzLnN0cm9rZVNpemU7XG5cbmNvbnN0IENoZWNrYm94Qm94SW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIC0tY2hlY2tDb2xvcjogJHtnZXRDb2xvcignc2hhZGUyJyl9O1xuICAtLWJhY2tncm91bmRDb2xvcjogdHJhbnNwYXJlbnQ7XG4gIC0tYmFja2dyb3VuZENvbG9yQWN0aXZlOiAke2dldENvbG9yKCdzaGFkZTEyJyl9O1xuICAtLWJvcmRlckNvbG9yOiAke2dldENvbG9yKCdzaGFkZTYnKX07XG5cbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgaGVpZ2h0OiAke3NpemV9cHg7XG4gIHdpZHRoOiAke3NpemV9cHg7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygneHMnKX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luOiAwO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvcik7XG4gIGJvcmRlcjogJHtzdHJva2VTaXplfSBzb2xpZCB2YXIoLS1ib3JkZXJDb2xvcik7XG4gIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2dldFRyYW5zaXRpb24oJ2xlYXZlJyl9O1xuXG4gICY6aG92ZXIge1xuICAgIC0tYm9yZGVyQ29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlMTInKX07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7Z2V0VHJhbnNpdGlvbignaG92ZXInKX07XG4gIH1cblxuICAmOmNoZWNrZWQge1xuICAgIC0tYm9yZGVyQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG4gICAgLS1iYWNrZ3JvdW5kQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG4gIH1cblxuICAmOmJlZm9yZSxcbiAgJjphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIGJhY2tncm91bmQ6IHZhcigtLWNoZWNrQ29sb3IpO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIHRyYW5zZm9ybTogcm90YXRlKC00NWRlZyk7XG4gICAgdHJhbnNmb3JtLW9yaWdpbjogYm90dG9tIGxlZnQ7XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgICBib3JkZXItcmFkaXVzOiAke2NoZWNrU3Ryb2tlfXB4O1xuICAgIGxlZnQ6ICR7KHNpemUgLSBjaGVja1dpZHRoKSAvIDJ9cHg7XG4gICAgYm90dG9tOiAkeyhzaXplIC0gY2hlY2tIZWlnaHQpIC8gMn1weDtcbiAgfVxuXG4gICY6YmVmb3JlIHtcbiAgICB3aWR0aDogJHtjaGVja1N0cm9rZX1weDtcbiAgICBoZWlnaHQ6ICR7Y2hlY2tXaWR0aH1weDtcbiAgfVxuXG4gICY6YWZ0ZXIge1xuICAgIHdpZHRoOiAke2NoZWNrSGVpZ2h0fXB4O1xuICAgIGhlaWdodDogJHtjaGVja1N0cm9rZX1weDtcbiAgfVxuXG4gICY6Y2hlY2tlZDpiZWZvcmUsXG4gICY6Y2hlY2tlZDphZnRlciB7XG4gICAgb3BhY2l0eTogMTtcbiAgfVxuXG4gICR7KHsgaXNJbmRldGVybWluYXRlIH0pID0+XG4gICAgaXNJbmRldGVybWluYXRlICYmXG4gICAgYFxuICAgICY6bm90KDpjaGVja2VkKSB7XG4gICAgICAtLWJvcmRlckNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kQ29sb3JBY3RpdmUpO1xuICAgICAgLS1iYWNrZ3JvdW5kQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG5cbiAgICAgICY6YmVmb3JlIHtcbiAgICAgICAgY29udGVudDogdW5zZXQ7XG4gICAgICB9XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgbWFyZ2luOiBhdXRvO1xuICAgICAgICBvcGFjaXR5OiAxO1xuICAgICAgfVxuICAgIH1cbiAgYH1cblxuICAmOmRpc2FibGVkIHtcbiAgICAtLWNoZWNrQ29sb3I6ICR7Z2V0Q29sb3IoJ2Rpc2FibGVkQ29udGVudCcpfTtcbiAgICAtLWJhY2tncm91bmRDb2xvcjogJHtnZXRDb2xvcignZGlzYWJsZWRCYWNrZ3JvdW5kJyl9O1xuICAgIC0tYmFja2dyb3VuZENvbG9yQWN0aXZlOiAke2dldENvbG9yKCdkaXNhYmxlZEJhY2tncm91bmQnKX07XG4gICAgLS1ib3JkZXJDb2xvcjogdHJhbnNwYXJlbnQ7XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gIH1cbmA7XG5cbmNvbnN0IENoZWNrYm94Qm94ID0gKHsgb25DaGFuZ2UgPSAoKSA9PiB7fSwgLi4ucHJvcHMgfSkgPT4gKFxuICA8Q2hlY2tib3hCb3hJbnB1dCB7Li4ucHJvcHN9IG9uQ2hhbmdlPXtvbkNoYW5nZX0gdHlwZT1cImNoZWNrYm94XCIgLz5cbik7XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQuZGl2YFxuICAkeyh7IGhhc1RleHQgfSkgPT5cbiAgICBoYXNUZXh0ICYmXG4gICAgYFxuICAgICAgZGlzcGxheTogZ3JpZDtcbiAgICAgIGdyaWQtYXV0by1mbG93OiBjb2x1bW47XG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgY29sdW1uLWdhcDogJHtnZXRTcGFjZSgnYmV0d2VlbkZvcm1Db250cm9sQW5kTGFiZWwnKX07XG4gICAgYH1cblxuICAuY2hlY2tib3hIaW50LCAuY2hlY2tib3hMYWJlbCB7XG4gICAgZ3JpZC1jb2x1bW46IDIgLyAzO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2hlY2tib3ggPSAoe1xuICBpc0Rpc2FibGVkLFxuICBpc0NoZWNrZWQsXG4gIGlzSW5kZXRlcm1pbmF0ZSxcbiAgbGFiZWwsXG4gIGhpbnQsXG4gIGlkLFxuICBvbkNoYW5nZSxcbiAgLi4ucHJvcHNcbn0pID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Um9vdCBoYXNUZXh0PXtsYWJlbCB8fCBoaW50fSB7Li4ucHJvcHN9PlxuICAgICAgPENoZWNrYm94Qm94XG4gICAgICAgIHR5cGU9XCJjaGVja2JveFwiXG4gICAgICAgIGRpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICBpZD17aWR9XG4gICAgICAgIGNoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICBpc0luZGV0ZXJtaW5hdGU9e2lzSW5kZXRlcm1pbmF0ZX1cbiAgICAgIC8+XG4gICAgICB7bGFiZWwgJiYgKFxuICAgICAgICA8RmllbGRMYWJlbCBodG1sRm9yPXtpZH0gY2xhc3NOYW1lPVwiY2hlY2tib3hMYWJlbFwiPlxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9GaWVsZExhYmVsPlxuICAgICAgKX1cbiAgICAgIHtoaW50ICYmIDxGaWVsZEhpbnQgY2xhc3NOYW1lPVwiY2hlY2tib3hIaW50XCI+e2hpbnR9PC9GaWVsZEhpbnQ+fVxuICAgIDwvUm9vdD5cbiAgKTtcbn07XG5cbkNoZWNrYm94LkxhYmVsID0gRmllbGRMYWJlbDtcbkNoZWNrYm94LkJveCA9IENoZWNrYm94Qm94O1xuXG5DaGVja2JveC5wcm9wVHlwZXMgPSB7XG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGlzQ2hlY2tlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGlzSW5kZXRlcm1pbmF0ZTogUHJvcFR5cGVzLmJvb2wsXG4gIGxhYmVsOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBoaW50OiB0eXBlcy5oaW50LFxufTtcbiJdfQ== */"));
56
+ }, " .checkboxHint,.checkboxLabel{grid-column:2/3;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2NoZWNrYm94LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF5R3VCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2NoZWNrYm94LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldENvbG9yLCBnZXRSYWRpdXMsIGdldFNwYWNlLCBnZXRUcmFuc2l0aW9uIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgRmllbGRIaW50LCBGaWVsZExhYmVsIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5jb25zdCBzaXplID0gMTY7XG5jb25zdCBjaGVja0hlaWdodCA9IHNpemUgLyAxLjY7XG5jb25zdCBjaGVja1dpZHRoID0gY2hlY2tIZWlnaHQgLyAyO1xuY29uc3QgY2hlY2tTdHJva2UgPSAxLjU7XG5cbmNvbnN0IENoZWNrYm94Qm94SW5wdXQgPSBzdHlsZWQuaW5wdXRgXG4gIC0tY2hlY2tDb2xvcjogJHtnZXRDb2xvcignc2hhZGUyJyl9O1xuICAtLWJhY2tncm91bmRDb2xvcjogdHJhbnNwYXJlbnQ7XG4gIC0tYmFja2dyb3VuZENvbG9yQWN0aXZlOiAke2dldENvbG9yKCdzaGFkZTEyJyl9O1xuICAtLWJvcmRlckNvbG9yOiAke2dldENvbG9yKCdzaGFkZTYnKX07XG5cbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgaGVpZ2h0OiAke3NpemV9cHg7XG4gIHdpZHRoOiAke3NpemV9cHg7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygneHMnKX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgbWFyZ2luOiAwO1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvcik7XG4gIGJvcmRlcjogdmFyKC0tZ3JuLWJvcmRlci1zaXplKSBzb2xpZCB2YXIoLS1ib3JkZXJDb2xvcik7XG4gIHRyYW5zaXRpb246IGJvcmRlci1jb2xvciAke2dldFRyYW5zaXRpb24oJ2xlYXZlJyl9O1xuXG4gICY6aG92ZXIge1xuICAgIC0tYm9yZGVyQ29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlMTInKX07XG4gICAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7Z2V0VHJhbnNpdGlvbignaG92ZXInKX07XG4gIH1cblxuICAmOmNoZWNrZWQge1xuICAgIC0tYm9yZGVyQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG4gICAgLS1iYWNrZ3JvdW5kQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG4gIH1cblxuICAmOmJlZm9yZSxcbiAgJjphZnRlciB7XG4gICAgY29udGVudDogJyc7XG4gICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgIGJhY2tncm91bmQ6IHZhcigtLWNoZWNrQ29sb3IpO1xuICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgIHRyYW5zZm9ybTogcm90YXRlKC00NWRlZyk7XG4gICAgdHJhbnNmb3JtLW9yaWdpbjogYm90dG9tIGxlZnQ7XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gICAgb3BhY2l0eTogMDtcbiAgICBib3JkZXItcmFkaXVzOiAke2NoZWNrU3Ryb2tlfXB4O1xuICAgIGxlZnQ6ICR7KHNpemUgLSBjaGVja1dpZHRoKSAvIDJ9cHg7XG4gICAgYm90dG9tOiAkeyhzaXplIC0gY2hlY2tIZWlnaHQpIC8gMn1weDtcbiAgfVxuXG4gICY6YmVmb3JlIHtcbiAgICB3aWR0aDogJHtjaGVja1N0cm9rZX1weDtcbiAgICBoZWlnaHQ6ICR7Y2hlY2tXaWR0aH1weDtcbiAgfVxuXG4gICY6YWZ0ZXIge1xuICAgIHdpZHRoOiAke2NoZWNrSGVpZ2h0fXB4O1xuICAgIGhlaWdodDogJHtjaGVja1N0cm9rZX1weDtcbiAgfVxuXG4gICY6Y2hlY2tlZDpiZWZvcmUsXG4gICY6Y2hlY2tlZDphZnRlciB7XG4gICAgb3BhY2l0eTogMTtcbiAgfVxuXG4gICR7KHsgaXNJbmRldGVybWluYXRlIH0pID0+XG4gICAgaXNJbmRldGVybWluYXRlICYmXG4gICAgYFxuICAgICY6bm90KDpjaGVja2VkKSB7XG4gICAgICAtLWJvcmRlckNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kQ29sb3JBY3RpdmUpO1xuICAgICAgLS1iYWNrZ3JvdW5kQ29sb3I6IHZhcigtLWJhY2tncm91bmRDb2xvckFjdGl2ZSk7XG5cbiAgICAgICY6YmVmb3JlIHtcbiAgICAgICAgY29udGVudDogdW5zZXQ7XG4gICAgICB9XG4gICAgICAmOmFmdGVyIHtcbiAgICAgICAgdHJhbnNmb3JtOiByb3RhdGUoMGRlZyk7XG4gICAgICAgIGxlZnQ6IDA7XG4gICAgICAgIHJpZ2h0OiAwO1xuICAgICAgICB0b3A6IDA7XG4gICAgICAgIGJvdHRvbTogMDtcbiAgICAgICAgbWFyZ2luOiBhdXRvO1xuICAgICAgICBvcGFjaXR5OiAxO1xuICAgICAgfVxuICAgIH1cbiAgYH1cblxuICAmOmRpc2FibGVkIHtcbiAgICAtLWNoZWNrQ29sb3I6ICR7Z2V0Q29sb3IoJ2Rpc2FibGVkQ29udGVudCcpfTtcbiAgICAtLWJhY2tncm91bmRDb2xvcjogJHtnZXRDb2xvcignZGlzYWJsZWRCYWNrZ3JvdW5kJyl9O1xuICAgIC0tYmFja2dyb3VuZENvbG9yQWN0aXZlOiAke2dldENvbG9yKCdkaXNhYmxlZEJhY2tncm91bmQnKX07XG4gICAgLS1ib3JkZXJDb2xvcjogdHJhbnNwYXJlbnQ7XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gIH1cbmA7XG5cbmNvbnN0IENoZWNrYm94Qm94ID0gKHsgb25DaGFuZ2UgPSAoKSA9PiB7fSwgLi4ucHJvcHMgfSkgPT4gKFxuICA8Q2hlY2tib3hCb3hJbnB1dCB7Li4ucHJvcHN9IG9uQ2hhbmdlPXtvbkNoYW5nZX0gdHlwZT1cImNoZWNrYm94XCIgLz5cbik7XG5cbmNvbnN0IFJvb3QgPSBzdHlsZWQuZGl2YFxuICAkeyh7IGhhc1RleHQgfSkgPT5cbiAgICBoYXNUZXh0ICYmXG4gICAgYFxuICAgICAgZGlzcGxheTogZ3JpZDtcbiAgICAgIGdyaWQtYXV0by1mbG93OiBjb2x1bW47XG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgd2lkdGg6IGZpdC1jb250ZW50O1xuICAgICAgY29sdW1uLWdhcDogJHtnZXRTcGFjZSgnYmV0d2VlbkZvcm1Db250cm9sQW5kTGFiZWwnKX07XG4gICAgYH1cblxuICAuY2hlY2tib3hIaW50LCAuY2hlY2tib3hMYWJlbCB7XG4gICAgZ3JpZC1jb2x1bW46IDIgLyAzO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgQ2hlY2tib3ggPSAoe1xuICBpc0Rpc2FibGVkLFxuICBpc0NoZWNrZWQsXG4gIGlzSW5kZXRlcm1pbmF0ZSxcbiAgbGFiZWwsXG4gIGhpbnQsXG4gIGlkLFxuICBvbkNoYW5nZSxcbiAgLi4ucHJvcHNcbn0pID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Um9vdCBoYXNUZXh0PXtsYWJlbCB8fCBoaW50fSB7Li4ucHJvcHN9PlxuICAgICAgPENoZWNrYm94Qm94XG4gICAgICAgIHR5cGU9XCJjaGVja2JveFwiXG4gICAgICAgIGRpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICBpZD17aWR9XG4gICAgICAgIGNoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgb25DaGFuZ2U9e29uQ2hhbmdlfVxuICAgICAgICBpc0luZGV0ZXJtaW5hdGU9e2lzSW5kZXRlcm1pbmF0ZX1cbiAgICAgIC8+XG4gICAgICB7bGFiZWwgJiYgKFxuICAgICAgICA8RmllbGRMYWJlbCBodG1sRm9yPXtpZH0gY2xhc3NOYW1lPVwiY2hlY2tib3hMYWJlbFwiPlxuICAgICAgICAgIHtsYWJlbH1cbiAgICAgICAgPC9GaWVsZExhYmVsPlxuICAgICAgKX1cbiAgICAgIHtoaW50ICYmIDxGaWVsZEhpbnQgY2xhc3NOYW1lPVwiY2hlY2tib3hIaW50XCI+e2hpbnR9PC9GaWVsZEhpbnQ+fVxuICAgIDwvUm9vdD5cbiAgKTtcbn07XG5cbkNoZWNrYm94LkxhYmVsID0gRmllbGRMYWJlbDtcbkNoZWNrYm94LkJveCA9IENoZWNrYm94Qm94O1xuXG5DaGVja2JveC5wcm9wVHlwZXMgPSB7XG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gIG9uQ2hhbmdlOiBQcm9wVHlwZXMuZnVuYyxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGlzQ2hlY2tlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGlzSW5kZXRlcm1pbmF0ZTogUHJvcFR5cGVzLmJvb2wsXG4gIGxhYmVsOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBoaW50OiB0eXBlcy5oaW50LFxufTtcbiJdfQ== */"));
58
57
 
59
58
  export const Checkbox = _ref4 => {
60
59
  let {
@@ -11,7 +11,7 @@ import { Icon } from './icon';
11
11
  import React, { forwardRef } from 'react';
12
12
  import PropTypes from 'prop-types';
13
13
  import { types } from '../types';
14
- import { componentVars, getClearButtonStyles } from '../foundational';
14
+ import { getClearButtonStyles } from '../foundational';
15
15
  import { jsx as ___EmotionJSX } from "@emotion/react";
16
16
 
17
17
  const Wrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
@@ -19,7 +19,7 @@ const Wrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "product
19
19
  } : {
20
20
  target: "evb8g3z0",
21
21
  label: "Wrapper"
22
- })(p => p.clearButtonStyles.box, ";min-width:", componentVars.clearButtonHeight, ";padding-left:8px;padding-right:8px;.Icon{", p => p.clearButtonStyles.icon, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2ljb24tYnV0dG9uLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPNkIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvaWNvbi1idXR0b24uanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4vaWNvbic7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGNvbXBvbmVudFZhcnMsIGdldENsZWFyQnV0dG9uU3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7cCA9PiBwLmNsZWFyQnV0dG9uU3R5bGVzLmJveH07XG4gIG1pbi13aWR0aDogJHtjb21wb25lbnRWYXJzLmNsZWFyQnV0dG9uSGVpZ2h0fTtcbiAgcGFkZGluZy1sZWZ0OiA4cHg7XG4gIHBhZGRpbmctcmlnaHQ6IDhweDtcblxuICAuSWNvbiB7XG4gICAgJHtwID0+IHAuY2xlYXJCdXR0b25TdHlsZXMuaWNvbn07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJY29uQnV0dG9uID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgaXNEaXNhYmxlZCxcbiAgICAgIGljb24sXG4gICAgICBjb2xvcixcbiAgICAgIHZhcmlhbnQgPSAnbmV1dHJhbCcsXG4gICAgICB0eXBlID0gJ2J1dHRvbicsXG4gICAgICBpc0FjdGl2ZSxcbiAgICAgIHRhZyA9ICdidXR0b24nLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgY2xlYXJCdXR0b25TdHlsZXMgPSBnZXRDbGVhckJ1dHRvblN0eWxlcyh7IHZhcmlhbnQsIGlzRGlzYWJsZWQsIGlzQWN0aXZlIH0pO1xuICAgIHJldHVybiAoXG4gICAgICA8V3JhcHBlclxuICAgICAgICB0eXBlPXt0eXBlfVxuICAgICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgaWNvbj17aWNvbn1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIHZhcmlhbnQ9e3ZhcmlhbnR9XG4gICAgICAgIGNsZWFyQnV0dG9uU3R5bGVzPXtjbGVhckJ1dHRvblN0eWxlc31cbiAgICAgICAgYXM9e3RhZ31cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgPlxuICAgICAgICB7aWNvbiAmJiA8SWNvbiBpY29uPXtpY29ufSAvPn1cbiAgICAgICAge2NoaWxkcmVuICYmIGNoaWxkcmVufVxuICAgICAgPC9XcmFwcGVyPlxuICAgICk7XG4gIH0sXG4pO1xuXG5JY29uQnV0dG9uLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBpY29uOiBQcm9wVHlwZXMubm9kZSxcbiAgb25DbGljazogUHJvcFR5cGVzLmZ1bmMsXG4gIGlzRGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICBpc0FjdGl2ZTogUHJvcFR5cGVzLmJvb2wsXG4gIHZhcmlhbnQ6IHR5cGVzLmNsZWFyQnV0dG9uVmFyaWFudCxcbiAgdHlwZTogdHlwZXMuYnV0dG9uVHlwZSxcbiAgdGFnOiB0eXBlcy5idXR0b25UYWcsXG59O1xuIl19 */"));
22
+ })(p => p.clearButtonStyles.box, ";min-width:var(--grn-clearbutton-height);padding-left:8px;padding-right:8px;.Icon{", p => p.clearButtonStyles.icon, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2ljb24tYnV0dG9uLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPNkIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvaWNvbi1idXR0b24uanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4vaWNvbic7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGdldENsZWFyQnV0dG9uU3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7cCA9PiBwLmNsZWFyQnV0dG9uU3R5bGVzLmJveH07XG4gIG1pbi13aWR0aDogdmFyKC0tZ3JuLWNsZWFyYnV0dG9uLWhlaWdodCk7XG4gIHBhZGRpbmctbGVmdDogOHB4O1xuICBwYWRkaW5nLXJpZ2h0OiA4cHg7XG5cbiAgLkljb24ge1xuICAgICR7cCA9PiBwLmNsZWFyQnV0dG9uU3R5bGVzLmljb259O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgSWNvbkJ1dHRvbiA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBjaGlsZHJlbixcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICBpY29uLFxuICAgICAgY29sb3IsXG4gICAgICB2YXJpYW50ID0gJ25ldXRyYWwnLFxuICAgICAgdHlwZSA9ICdidXR0b24nLFxuICAgICAgaXNBY3RpdmUsXG4gICAgICB0YWcgPSAnYnV0dG9uJyxcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIGNvbnN0IGNsZWFyQnV0dG9uU3R5bGVzID0gZ2V0Q2xlYXJCdXR0b25TdHlsZXMoeyB2YXJpYW50LCBpc0Rpc2FibGVkLCBpc0FjdGl2ZSB9KTtcbiAgICByZXR1cm4gKFxuICAgICAgPFdyYXBwZXJcbiAgICAgICAgdHlwZT17dHlwZX1cbiAgICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGljb249e2ljb259XG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgICBjbGVhckJ1dHRvblN0eWxlcz17Y2xlYXJCdXR0b25TdHlsZXN9XG4gICAgICAgIGFzPXt0YWd9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgID5cbiAgICAgICAge2ljb24gJiYgPEljb24gaWNvbj17aWNvbn0gLz59XG4gICAgICAgIHtjaGlsZHJlbiAmJiBjaGlsZHJlbn1cbiAgICAgIDwvV3JhcHBlcj5cbiAgICApO1xuICB9LFxuKTtcblxuSWNvbkJ1dHRvbi5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaWNvbjogUHJvcFR5cGVzLm5vZGUsXG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxuICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNBY3RpdmU6IFByb3BUeXBlcy5ib29sLFxuICB2YXJpYW50OiB0eXBlcy5jbGVhckJ1dHRvblZhcmlhbnQsXG4gIHR5cGU6IHR5cGVzLmJ1dHRvblR5cGUsXG4gIHRhZzogdHlwZXMuYnV0dG9uVGFnLFxufTtcbiJdfQ== */"));
23
23
 
24
24
  export const IconButton = /*#__PURE__*/forwardRef((_ref, ref) => {
25
25
  let {