@flodesk/grain 11.69.0-next.16 → 11.69.0-next.18
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.
- package/es/components/autocomplete2.js +43 -37
- package/es/components/ghost-input.js +5 -5
- package/es/components/icon-toggle.js +2 -2
- package/es/components/select.js +29 -24
- package/es/components/text-toggle.js +2 -2
- package/es/components/textarea.js +5 -20
- package/es/styles/colors/core.js +1 -1
- package/package.json +1 -1
|
@@ -56,28 +56,33 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
|
|
|
56
56
|
marginTop
|
|
57
57
|
} = _ref6;
|
|
58
58
|
return getSpace(marginTop);
|
|
59
|
-
}, ";border-radius:",
|
|
59
|
+
}, ";border-radius:", _ref7 => {
|
|
60
60
|
let {
|
|
61
|
-
|
|
61
|
+
size
|
|
62
62
|
} = _ref7;
|
|
63
|
-
return
|
|
64
|
-
}, ";
|
|
63
|
+
return "var(--grn-textbox-radius-".concat(size, ")");
|
|
64
|
+
}, ";box-shadow:inset 0 0 0 var(--grn-border-size) var(--borderColor);background-color:var(--backgroundColor);.autocompleteInput{line-height:20px;border:none;opacity:", _ref8 => {
|
|
65
65
|
let {
|
|
66
66
|
open
|
|
67
67
|
} = _ref8;
|
|
68
|
+
return open ? 1 : 0;
|
|
69
|
+
}, ";pointer-events:", _ref9 => {
|
|
70
|
+
let {
|
|
71
|
+
open
|
|
72
|
+
} = _ref9;
|
|
68
73
|
return open ? 'auto' : 'none';
|
|
69
|
-
}, ";transition:opacity ", transitionSpeed, ";background:transparent;&: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, Spinner } from '.';\nimport { IconChevronDown, IconPlus, IconCross } 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: transparent;\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('contentDanger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: var(--grn-field-background);\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    background: transparent;\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 rightSectionGap = 'var(--grn-space-m)';\n\nconst RightSection = ({ children, right }) => (\n  <Arrange\n    right={right}\n    gap={rightSectionGap}\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"100%\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick, ...props }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} {...props} />;\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('overlay')};\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(function Item(\n  { children, hasEllipsis, paddingLeft = '12px', ...props },\n  ref,\n) {\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: ${({ size }) => `var(--grn-textbox-height-${size})`};\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: ${({ paddingRight }) => paddingRight};\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-right: ${({ paddingRight }) => paddingRight};\n  padding-left: ${({ paddingLeft }) => paddingLeft};\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  hasSpinner,\n  size = 'm',\n  renderGroupTitle,\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 ? 'var(--grn-form-control-label-gap)' : 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 inputPaddingX = `var(--grn-field-paddingX-${size})`;\n\n  const chevronWidth = `${IconChevronDown.viewBoxWidth / 2}px`;\n  const textGap = 'var(--grn-space-s2)';\n  const spinnerSpace = `calc(var(--grn-unit) * 3) + ${rightSectionGap}`;\n  const iconCrossWidth = `${IconCross.viewBoxWidth / 2}px`;\n  const clearButtonSpace = `${iconCrossWidth} + ${rightSectionGap}`;\n\n  const paddingRightValues = [textGap];\n  if (hasSpinner) paddingRightValues.push(spinnerSpace);\n  if (hasClearButton) paddingRightValues.push(clearButtonSpace);\n  paddingRightValues.push(chevronWidth, inputPaddingX);\n\n  const inputPaddingRight = `calc(${paddingRightValues.join(' + ')})`;\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                    size={size}\n                  />\n\n                  <Trigger open={open} tabIndex={-1} paddingRight={inputPaddingRight} size={size}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight} paddingLeft={inputPaddingX}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <RightSection right={inputPaddingX}>\n                    {hasSpinner && <Spinner />}\n                    {hasClearButton && <ClearButton onClick={onClear} trimSides />}\n                    <Icon icon={<IconChevronDown />} />\n                  </RightSection>\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                              (renderGroupTitle ? (\n                                renderGroupTitle(option.groupTitle)\n                              ) : (\n                                <MenuGroupTitle>{option.groupTitle}</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=\"var(--grn-form-control-label-gap)\" color=\"contentDanger\">\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  hasSpinner: PropTypes.bool,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
74
|
+
}, ";transition:opacity ", transitionSpeed, ";background:transparent;&: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, Spinner } from '.';\nimport { IconChevronDown, IconPlus, IconCross } 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: transparent;\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('contentDanger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: var(--grn-field-background);\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: ${({ size }) => `var(--grn-textbox-radius-${size})`};\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    background: transparent;\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 rightSectionGap = 'var(--grn-space-m)';\n\nconst RightSection = ({ children, right }) => (\n  <Arrange\n    right={right}\n    gap={rightSectionGap}\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"100%\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick, ...props }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} {...props} />;\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('overlay')};\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(function Item(\n  { children, hasEllipsis, paddingLeft = '12px', ...props },\n  ref,\n) {\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: ${({ size }) => `var(--grn-textbox-height-${size})`};\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: ${({ paddingRight }) => paddingRight};\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-right: ${({ paddingRight }) => paddingRight};\n  padding-left: ${({ paddingLeft }) => paddingLeft};\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  hasSpinner,\n  size = 'm',\n  renderGroupTitle,\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 ? 'var(--grn-form-control-label-gap)' : 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 inputPaddingX = `var(--grn-field-paddingX-${size})`;\n\n  const chevronWidth = `${IconChevronDown.viewBoxWidth / 2}px`;\n  const textGap = 'var(--grn-space-s2)';\n  const spinnerSpace = `calc(var(--grn-unit) * 3) + ${rightSectionGap}`;\n  const iconCrossWidth = `${IconCross.viewBoxWidth / 2}px`;\n  const clearButtonSpace = `${iconCrossWidth} + ${rightSectionGap}`;\n\n  const paddingRightValues = [textGap];\n  if (hasSpinner) paddingRightValues.push(spinnerSpace);\n  if (hasClearButton) paddingRightValues.push(clearButtonSpace);\n  paddingRightValues.push(chevronWidth, inputPaddingX);\n\n  const inputPaddingRight = `calc(${paddingRightValues.join(' + ')})`;\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                size={size}\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                    size={size}\n                  />\n\n                  <Trigger open={open} tabIndex={-1} paddingRight={inputPaddingRight} size={size}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight} paddingLeft={inputPaddingX}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <RightSection right={inputPaddingX}>\n                    {hasSpinner && <Spinner />}\n                    {hasClearButton && <ClearButton onClick={onClear} trimSides />}\n                    <Icon icon={<IconChevronDown />} />\n                  </RightSection>\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                              (renderGroupTitle ? (\n                                renderGroupTitle(option.groupTitle)\n                              ) : (\n                                <MenuGroupTitle>{option.groupTitle}</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=\"var(--grn-form-control-label-gap)\" color=\"contentDanger\">\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  hasSpinner: PropTypes.bool,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
70
75
|
const EmptyState = () => ___EmotionJSX(Box, {
|
|
71
76
|
paddingY: "s",
|
|
72
77
|
paddingX: "m",
|
|
73
78
|
color: "content2"
|
|
74
79
|
}, "No results");
|
|
75
80
|
const rightSectionGap = 'var(--grn-space-m)';
|
|
76
|
-
const RightSection =
|
|
81
|
+
const RightSection = _ref0 => {
|
|
77
82
|
let {
|
|
78
83
|
children,
|
|
79
84
|
right
|
|
80
|
-
} =
|
|
85
|
+
} = _ref0;
|
|
81
86
|
return ___EmotionJSX(Arrange, {
|
|
82
87
|
right: right,
|
|
83
88
|
gap: rightSectionGap,
|
|
@@ -88,11 +93,11 @@ const RightSection = _ref9 => {
|
|
|
88
93
|
height: "100%"
|
|
89
94
|
}, children);
|
|
90
95
|
};
|
|
91
|
-
const ClearButton =
|
|
96
|
+
const ClearButton = _ref1 => {
|
|
92
97
|
let {
|
|
93
98
|
onClick
|
|
94
|
-
} =
|
|
95
|
-
props = _objectWithoutProperties(
|
|
99
|
+
} = _ref1,
|
|
100
|
+
props = _objectWithoutProperties(_ref1, _excluded);
|
|
96
101
|
const handleClear = e => {
|
|
97
102
|
e.stopPropagation();
|
|
98
103
|
onClick();
|
|
@@ -111,13 +116,13 @@ const getShowGroupTitle = (index, option, filteredOptions) => {
|
|
|
111
116
|
return firstOptionHasTitle || titleChanged;
|
|
112
117
|
};
|
|
113
118
|
const 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: ".concat(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: ").concat(getColor('overlay'), ";\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 ").concat(getIconSize('m'), ";\n }\n\n &[data-headlessui-state='active selected'] {\n background-image: var(--checkUriActive);\n }\n\n &[data-headlessui-state='disabled'] {\n color: ").concat(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");
|
|
114
|
-
const Item = /*#__PURE__*/forwardRef(function Item(
|
|
119
|
+
const Item = /*#__PURE__*/forwardRef(function Item(_ref10, ref) {
|
|
115
120
|
let {
|
|
116
121
|
children,
|
|
117
122
|
hasEllipsis,
|
|
118
123
|
paddingLeft = '12px'
|
|
119
|
-
} =
|
|
120
|
-
props = _objectWithoutProperties(
|
|
124
|
+
} = _ref10,
|
|
125
|
+
props = _objectWithoutProperties(_ref10, _excluded2);
|
|
121
126
|
return ___EmotionJSX("li", _extends({
|
|
122
127
|
className: "autocompleteMenuItem",
|
|
123
128
|
ref: ref,
|
|
@@ -133,44 +138,44 @@ const Trigger = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "product
|
|
|
133
138
|
} : {
|
|
134
139
|
target: "ea1qwwn1",
|
|
135
140
|
label: "Trigger"
|
|
136
|
-
})("text-align:left;height:",
|
|
141
|
+
})("text-align:left;height:", _ref11 => {
|
|
137
142
|
let {
|
|
138
143
|
size
|
|
139
|
-
} =
|
|
144
|
+
} = _ref11;
|
|
140
145
|
return "var(--grn-textbox-height-".concat(size, ")");
|
|
141
|
-
}, ";background-color:transparent;cursor:text;appearance:none;display:block;font:inherit;color:inherit;width:100%;outline:none;border:none;padding:0;opacity:",
|
|
146
|
+
}, ";background-color:transparent;cursor:text;appearance:none;display:block;font:inherit;color:inherit;width:100%;outline:none;border:none;padding:0;opacity:", _ref12 => {
|
|
142
147
|
let {
|
|
143
148
|
open
|
|
144
|
-
} =
|
|
149
|
+
} = _ref12;
|
|
145
150
|
return open ? 0 : 1;
|
|
146
|
-
}, ";pointer-events:",
|
|
151
|
+
}, ";pointer-events:", _ref13 => {
|
|
147
152
|
let {
|
|
148
153
|
open
|
|
149
|
-
} =
|
|
154
|
+
} = _ref13;
|
|
150
155
|
return open ? 'none' : 'auto';
|
|
151
|
-
}, ";position:absolute;top:0;left:0;transition:opacity ", transitionSpeed, ";.autocompleteMenuItem{padding-right:",
|
|
156
|
+
}, ";position:absolute;top:0;left:0;transition:opacity ", transitionSpeed, ";.autocompleteMenuItem{padding-right:", _ref14 => {
|
|
152
157
|
let {
|
|
153
158
|
paddingRight
|
|
154
|
-
} =
|
|
159
|
+
} = _ref14;
|
|
155
160
|
return paddingRight;
|
|
156
|
-
}, ";}.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":"AA6M6B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange, Spinner } from '.';\nimport { IconChevronDown, IconPlus, IconCross } 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: transparent;\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('contentDanger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: var(--grn-field-background);\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    background: transparent;\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 rightSectionGap = 'var(--grn-space-m)';\n\nconst RightSection = ({ children, right }) => (\n  <Arrange\n    right={right}\n    gap={rightSectionGap}\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"100%\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick, ...props }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} {...props} />;\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('overlay')};\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(function Item(\n  { children, hasEllipsis, paddingLeft = '12px', ...props },\n  ref,\n) {\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: ${({ size }) => `var(--grn-textbox-height-${size})`};\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: ${({ paddingRight }) => paddingRight};\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-right: ${({ paddingRight }) => paddingRight};\n  padding-left: ${({ paddingLeft }) => paddingLeft};\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  hasSpinner,\n  size = 'm',\n  renderGroupTitle,\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 ? 'var(--grn-form-control-label-gap)' : 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 inputPaddingX = `var(--grn-field-paddingX-${size})`;\n\n  const chevronWidth = `${IconChevronDown.viewBoxWidth / 2}px`;\n  const textGap = 'var(--grn-space-s2)';\n  const spinnerSpace = `calc(var(--grn-unit) * 3) + ${rightSectionGap}`;\n  const iconCrossWidth = `${IconCross.viewBoxWidth / 2}px`;\n  const clearButtonSpace = `${iconCrossWidth} + ${rightSectionGap}`;\n\n  const paddingRightValues = [textGap];\n  if (hasSpinner) paddingRightValues.push(spinnerSpace);\n  if (hasClearButton) paddingRightValues.push(clearButtonSpace);\n  paddingRightValues.push(chevronWidth, inputPaddingX);\n\n  const inputPaddingRight = `calc(${paddingRightValues.join(' + ')})`;\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                    size={size}\n                  />\n\n                  <Trigger open={open} tabIndex={-1} paddingRight={inputPaddingRight} size={size}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight} paddingLeft={inputPaddingX}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <RightSection right={inputPaddingX}>\n                    {hasSpinner && <Spinner />}\n                    {hasClearButton && <ClearButton onClick={onClear} trimSides />}\n                    <Icon icon={<IconChevronDown />} />\n                  </RightSection>\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                              (renderGroupTitle ? (\n                                renderGroupTitle(option.groupTitle)\n                              ) : (\n                                <MenuGroupTitle>{option.groupTitle}</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=\"var(--grn-form-control-label-gap)\" color=\"contentDanger\">\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  hasSpinner: PropTypes.bool,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
161
|
+
}, ";}.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":"AA6M6B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange, Spinner } from '.';\nimport { IconChevronDown, IconPlus, IconCross } 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: transparent;\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('contentDanger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: var(--grn-field-background);\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: ${({ size }) => `var(--grn-textbox-radius-${size})`};\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    background: transparent;\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 rightSectionGap = 'var(--grn-space-m)';\n\nconst RightSection = ({ children, right }) => (\n  <Arrange\n    right={right}\n    gap={rightSectionGap}\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"100%\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick, ...props }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} {...props} />;\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('overlay')};\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(function Item(\n  { children, hasEllipsis, paddingLeft = '12px', ...props },\n  ref,\n) {\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: ${({ size }) => `var(--grn-textbox-height-${size})`};\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: ${({ paddingRight }) => paddingRight};\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-right: ${({ paddingRight }) => paddingRight};\n  padding-left: ${({ paddingLeft }) => paddingLeft};\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  hasSpinner,\n  size = 'm',\n  renderGroupTitle,\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 ? 'var(--grn-form-control-label-gap)' : 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 inputPaddingX = `var(--grn-field-paddingX-${size})`;\n\n  const chevronWidth = `${IconChevronDown.viewBoxWidth / 2}px`;\n  const textGap = 'var(--grn-space-s2)';\n  const spinnerSpace = `calc(var(--grn-unit) * 3) + ${rightSectionGap}`;\n  const iconCrossWidth = `${IconCross.viewBoxWidth / 2}px`;\n  const clearButtonSpace = `${iconCrossWidth} + ${rightSectionGap}`;\n\n  const paddingRightValues = [textGap];\n  if (hasSpinner) paddingRightValues.push(spinnerSpace);\n  if (hasClearButton) paddingRightValues.push(clearButtonSpace);\n  paddingRightValues.push(chevronWidth, inputPaddingX);\n\n  const inputPaddingRight = `calc(${paddingRightValues.join(' + ')})`;\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                size={size}\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                    size={size}\n                  />\n\n                  <Trigger open={open} tabIndex={-1} paddingRight={inputPaddingRight} size={size}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight} paddingLeft={inputPaddingX}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <RightSection right={inputPaddingX}>\n                    {hasSpinner && <Spinner />}\n                    {hasClearButton && <ClearButton onClick={onClear} trimSides />}\n                    <Icon icon={<IconChevronDown />} />\n                  </RightSection>\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                              (renderGroupTitle ? (\n                                renderGroupTitle(option.groupTitle)\n                              ) : (\n                                <MenuGroupTitle>{option.groupTitle}</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=\"var(--grn-form-control-label-gap)\" color=\"contentDanger\">\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  hasSpinner: PropTypes.bool,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
157
162
|
const TriggerText = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
|
|
158
163
|
target: "ea1qwwn0"
|
|
159
164
|
} : {
|
|
160
165
|
target: "ea1qwwn0",
|
|
161
166
|
label: "TriggerText"
|
|
162
|
-
})("line-height:20px;display:block;padding-block:0;padding-right:",
|
|
167
|
+
})("line-height:20px;display:block;padding-block:0;padding-right:", _ref15 => {
|
|
163
168
|
let {
|
|
164
169
|
paddingRight
|
|
165
|
-
} =
|
|
170
|
+
} = _ref15;
|
|
166
171
|
return paddingRight;
|
|
167
|
-
}, ";padding-left:",
|
|
172
|
+
}, ";padding-left:", _ref16 => {
|
|
168
173
|
let {
|
|
169
174
|
paddingLeft
|
|
170
|
-
} =
|
|
175
|
+
} = _ref16;
|
|
171
176
|
return paddingLeft;
|
|
172
|
-
}, ";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":"AA2O+B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange, Spinner } from '.';\nimport { IconChevronDown, IconPlus, IconCross } 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: transparent;\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('contentDanger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: var(--grn-field-background);\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    background: transparent;\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 rightSectionGap = 'var(--grn-space-m)';\n\nconst RightSection = ({ children, right }) => (\n  <Arrange\n    right={right}\n    gap={rightSectionGap}\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"100%\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick, ...props }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} {...props} />;\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('overlay')};\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(function Item(\n  { children, hasEllipsis, paddingLeft = '12px', ...props },\n  ref,\n) {\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: ${({ size }) => `var(--grn-textbox-height-${size})`};\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: ${({ paddingRight }) => paddingRight};\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-right: ${({ paddingRight }) => paddingRight};\n  padding-left: ${({ paddingLeft }) => paddingLeft};\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  hasSpinner,\n  size = 'm',\n  renderGroupTitle,\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 ? 'var(--grn-form-control-label-gap)' : 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 inputPaddingX = `var(--grn-field-paddingX-${size})`;\n\n  const chevronWidth = `${IconChevronDown.viewBoxWidth / 2}px`;\n  const textGap = 'var(--grn-space-s2)';\n  const spinnerSpace = `calc(var(--grn-unit) * 3) + ${rightSectionGap}`;\n  const iconCrossWidth = `${IconCross.viewBoxWidth / 2}px`;\n  const clearButtonSpace = `${iconCrossWidth} + ${rightSectionGap}`;\n\n  const paddingRightValues = [textGap];\n  if (hasSpinner) paddingRightValues.push(spinnerSpace);\n  if (hasClearButton) paddingRightValues.push(clearButtonSpace);\n  paddingRightValues.push(chevronWidth, inputPaddingX);\n\n  const inputPaddingRight = `calc(${paddingRightValues.join(' + ')})`;\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                    size={size}\n                  />\n\n                  <Trigger open={open} tabIndex={-1} paddingRight={inputPaddingRight} size={size}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight} paddingLeft={inputPaddingX}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <RightSection right={inputPaddingX}>\n                    {hasSpinner && <Spinner />}\n                    {hasClearButton && <ClearButton onClick={onClear} trimSides />}\n                    <Icon icon={<IconChevronDown />} />\n                  </RightSection>\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                              (renderGroupTitle ? (\n                                renderGroupTitle(option.groupTitle)\n                              ) : (\n                                <MenuGroupTitle>{option.groupTitle}</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=\"var(--grn-form-control-label-gap)\" color=\"contentDanger\">\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  hasSpinner: PropTypes.bool,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
173
|
-
export const Autocomplete2 =
|
|
177
|
+
}, ";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":"AA2O+B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Arrange, Spinner } from '.';\nimport { IconChevronDown, IconPlus, IconCross } 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: transparent;\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('contentDanger')};`};\n\n  ${({ backgroundColor, isDisabled }) =>\n    !backgroundColor &&\n    !isDisabled &&\n    `\n      --backgroundColor: var(--grn-field-background);\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: ${({ size }) => `var(--grn-textbox-radius-${size})`};\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    background: transparent;\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 rightSectionGap = 'var(--grn-space-m)';\n\nconst RightSection = ({ children, right }) => (\n  <Arrange\n    right={right}\n    gap={rightSectionGap}\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"100%\"\n  >\n    {children}\n  </Arrange>\n);\n\nconst ClearButton = ({ onClick, ...props }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} {...props} />;\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('overlay')};\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(function Item(\n  { children, hasEllipsis, paddingLeft = '12px', ...props },\n  ref,\n) {\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: ${({ size }) => `var(--grn-textbox-height-${size})`};\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: ${({ paddingRight }) => paddingRight};\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-right: ${({ paddingRight }) => paddingRight};\n  padding-left: ${({ paddingLeft }) => paddingLeft};\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  hasSpinner,\n  size = 'm',\n  renderGroupTitle,\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 ? 'var(--grn-form-control-label-gap)' : 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 inputPaddingX = `var(--grn-field-paddingX-${size})`;\n\n  const chevronWidth = `${IconChevronDown.viewBoxWidth / 2}px`;\n  const textGap = 'var(--grn-space-s2)';\n  const spinnerSpace = `calc(var(--grn-unit) * 3) + ${rightSectionGap}`;\n  const iconCrossWidth = `${IconCross.viewBoxWidth / 2}px`;\n  const clearButtonSpace = `${iconCrossWidth} + ${rightSectionGap}`;\n\n  const paddingRightValues = [textGap];\n  if (hasSpinner) paddingRightValues.push(spinnerSpace);\n  if (hasClearButton) paddingRightValues.push(clearButtonSpace);\n  paddingRightValues.push(chevronWidth, inputPaddingX);\n\n  const inputPaddingRight = `calc(${paddingRightValues.join(' + ')})`;\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                size={size}\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                    size={size}\n                  />\n\n                  <Trigger open={open} tabIndex={-1} paddingRight={inputPaddingRight} size={size}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText paddingRight={inputPaddingRight} paddingLeft={inputPaddingX}>\n                        {selectedOption?.content}\n                      </TriggerText>\n                    )}\n                  </Trigger>\n\n                  <RightSection right={inputPaddingX}>\n                    {hasSpinner && <Spinner />}\n                    {hasClearButton && <ClearButton onClick={onClear} trimSides />}\n                    <Icon icon={<IconChevronDown />} />\n                  </RightSection>\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                              (renderGroupTitle ? (\n                                renderGroupTitle(option.groupTitle)\n                              ) : (\n                                <MenuGroupTitle>{option.groupTitle}</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=\"var(--grn-form-control-label-gap)\" color=\"contentDanger\">\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  hasSpinner: PropTypes.bool,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
178
|
+
export const Autocomplete2 = _ref17 => {
|
|
174
179
|
let {
|
|
175
180
|
options,
|
|
176
181
|
value,
|
|
@@ -195,8 +200,8 @@ export const Autocomplete2 = _ref16 => {
|
|
|
195
200
|
hasSpinner,
|
|
196
201
|
size = 'm',
|
|
197
202
|
renderGroupTitle
|
|
198
|
-
} =
|
|
199
|
-
props = _objectWithoutProperties(
|
|
203
|
+
} = _ref17,
|
|
204
|
+
props = _objectWithoutProperties(_ref17, _excluded3);
|
|
200
205
|
const [query, setQuery] = useState('');
|
|
201
206
|
const handleCreatableChange = option => {
|
|
202
207
|
if (onCreate) {
|
|
@@ -252,10 +257,10 @@ export const Autocomplete2 = _ref16 => {
|
|
|
252
257
|
as: "div",
|
|
253
258
|
value: selectedOption || '',
|
|
254
259
|
onChange: handleChange
|
|
255
|
-
}, props),
|
|
260
|
+
}, props), _ref18 => {
|
|
256
261
|
let {
|
|
257
262
|
open
|
|
258
|
-
} =
|
|
263
|
+
} = _ref18;
|
|
259
264
|
const hasItem = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.item;
|
|
260
265
|
return ___EmotionJSX(React.Fragment, null, label && ___EmotionJSX(Combobox.Label, {
|
|
261
266
|
as: FieldLabel
|
|
@@ -265,7 +270,8 @@ export const Autocomplete2 = _ref16 => {
|
|
|
265
270
|
open: open,
|
|
266
271
|
hasError: hasError,
|
|
267
272
|
backgroundColor: backgroundColor,
|
|
268
|
-
isDisabled: isDisabled
|
|
273
|
+
isDisabled: isDisabled,
|
|
274
|
+
size: size
|
|
269
275
|
}, ___EmotionJSX(Combobox.Button, {
|
|
270
276
|
as: Box,
|
|
271
277
|
position: "relative"
|
|
@@ -317,10 +323,10 @@ export const Autocomplete2 = _ref16 => {
|
|
|
317
323
|
value: option,
|
|
318
324
|
as: Fragment,
|
|
319
325
|
disabled: option.isDisabled
|
|
320
|
-
},
|
|
326
|
+
}, _ref19 => {
|
|
321
327
|
let {
|
|
322
328
|
active
|
|
323
|
-
} =
|
|
329
|
+
} = _ref19;
|
|
324
330
|
const isDisabled = option.isDisabled;
|
|
325
331
|
const isSelected = option.value === value;
|
|
326
332
|
const isActive = !option.isDisabled && active;
|
|
@@ -340,10 +346,10 @@ export const Autocomplete2 = _ref16 => {
|
|
|
340
346
|
}), isShowCreateOption && ___EmotionJSX(React.Fragment, null, filteredOptions.length > 0 && ___EmotionJSX(MenuItemDivider, null), ___EmotionJSX(Combobox.Option, {
|
|
341
347
|
value: newOption,
|
|
342
348
|
as: Fragment
|
|
343
|
-
},
|
|
349
|
+
}, _ref20 => {
|
|
344
350
|
let {
|
|
345
351
|
active
|
|
346
|
-
} =
|
|
352
|
+
} = _ref20;
|
|
347
353
|
return ___EmotionJSX(Item, {
|
|
348
354
|
isActive: active,
|
|
349
355
|
hasEllipsis: menuItemsHaveEllipsis
|
|
@@ -19,7 +19,7 @@ const InputField = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "produ
|
|
|
19
19
|
prefixWidth
|
|
20
20
|
} = _ref;
|
|
21
21
|
return Boolean(prefixWidth) ? "calc(".concat(prefixWidth, "px + var(--padding))") : 'var(--padding)';
|
|
22
|
-
}, ";appearance:none;background:
|
|
22
|
+
}, ";appearance:none;background:transparent;display:block;font:inherit;color:inherit;border:none;position:absolute;width:calc(100% + var(--padding) * 2);left:calc(-1 * var(--padding));border:none;margin:auto;top:0;bottom:0;box-shadow:inset 0 0 0 1px transparent;border-radius:var(--grn-radius-s);transition:box-shadow var(--grn-transition-leave);padding-block:0;padding-left:var(--paddingLeft);padding-right:var(--padding);height:calc(var(--padding) * 2 + var(--grn-cap));", _ref2 => {
|
|
23
23
|
let {
|
|
24
24
|
hasEllipsis
|
|
25
25
|
} = _ref2;
|
|
@@ -29,7 +29,7 @@ const InputField = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "produ
|
|
|
29
29
|
isTabular
|
|
30
30
|
} = _ref3;
|
|
31
31
|
return isTabular && "font-feature-settings: 'tnum'";
|
|
32
|
-
}, ";&:hover{box-shadow:inset 0 0 0 1px var(--grn-field-border-color-hover);transition:var(--grn-transition-hover);}&:focus{outline:none;box-shadow:inset 0 0 0 1px var(--grn-field-border-color-focus);transition:var(--grn-transition-active);}&[type='number']::-webkit-outer-spin-button,&[type='number']::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
32
|
+
}, ";&:hover{box-shadow:inset 0 0 0 1px var(--grn-field-border-color-hover);transition:var(--grn-transition-hover);}&:focus{outline:none;box-shadow:inset 0 0 0 1px var(--grn-field-border-color-focus);transition:var(--grn-transition-active);}&[type='number']::-webkit-outer-spin-button,&[type='number']::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}&[type='number']{-moz-appearance:textfield;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNK0IiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvZ2hvc3QtaW5wdXQuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QsIHVzZVJlZiwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCB7IHVzZVdpZHRoIH0gZnJvbSAnLi4vaG9va3MnO1xuXG5jb25zdCBJbnB1dEZpZWxkID0gc3R5bGVkLmlucHV0YFxuICAtLXBhZGRpbmc6IHZhcigtLWdybi1zcGFjZS1zKTtcbiAgLS1wYWRkaW5nTGVmdDogJHsoeyBwcmVmaXhXaWR0aCB9KSA9PlxuICAgIEJvb2xlYW4ocHJlZml4V2lkdGgpID8gYGNhbGMoJHtwcmVmaXhXaWR0aH1weCArIHZhcigtLXBhZGRpbmcpKWAgOiAndmFyKC0tcGFkZGluZyknfTtcblxuICBhcHBlYXJhbmNlOiBub25lO1xuICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICBib3JkZXI6IG5vbmU7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgd2lkdGg6IGNhbGMoMTAwJSArIHZhcigtLXBhZGRpbmcpICogMik7XG4gIGxlZnQ6IGNhbGMoLTEgKiB2YXIoLS1wYWRkaW5nKSk7XG4gIGJvcmRlcjogbm9uZTtcbiAgbWFyZ2luOiBhdXRvO1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgYm94LXNoYWRvdzogaW5zZXQgMCAwIDAgMXB4IHRyYW5zcGFyZW50O1xuICBib3JkZXItcmFkaXVzOiB2YXIoLS1ncm4tcmFkaXVzLXMpO1xuICB0cmFuc2l0aW9uOiBib3gtc2hhZG93IHZhcigtLWdybi10cmFuc2l0aW9uLWxlYXZlKTtcbiAgcGFkZGluZy1ibG9jazogMDtcbiAgcGFkZGluZy1sZWZ0OiB2YXIoLS1wYWRkaW5nTGVmdCk7XG4gIHBhZGRpbmctcmlnaHQ6IHZhcigtLXBhZGRpbmcpO1xuICBoZWlnaHQ6IGNhbGModmFyKC0tcGFkZGluZykgKiAyICsgdmFyKC0tZ3JuLWNhcCkpO1xuXG4gICR7KHsgaGFzRWxsaXBzaXMgfSkgPT4gaGFzRWxsaXBzaXMgJiYgYHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzYH07XG4gICR7KHsgaXNUYWJ1bGFyIH0pID0+IGlzVGFidWxhciAmJiBgZm9udC1mZWF0dXJlLXNldHRpbmdzOiAndG51bSdgfTtcblxuICAmOmhvdmVyIHtcbiAgICBib3gtc2hhZG93OiBpbnNldCAwIDAgMCAxcHggdmFyKC0tZ3JuLWZpZWxkLWJvcmRlci1jb2xvci1ob3Zlcik7XG4gICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24taG92ZXIpO1xuICB9XG4gICY6Zm9jdXMge1xuICAgIG91dGxpbmU6IG5vbmU7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAwIDAgMXB4IHZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3ItZm9jdXMpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gIH1cblxuICAmW3R5cGU9J251bWJlciddOjotd2Via2l0LW91dGVyLXNwaW4tYnV0dG9uLFxuICAmW3R5cGU9J251bWJlciddOjotd2Via2l0LWlubmVyLXNwaW4tYnV0dG9uIHtcbiAgICAtd2Via2l0LWFwcGVhcmFuY2U6IG5vbmU7XG4gICAgbWFyZ2luOiAwO1xuICB9XG4gICZbdHlwZT0nbnVtYmVyJ10ge1xuICAgIC1tb3otYXBwZWFyYW5jZTogdGV4dGZpZWxkO1xuICB9XG5gO1xuXG5jb25zdCBIb2xkZXIgPSBzdHlsZWQuZGl2YFxuICAtLXBhZGRpbmc6IHZhcigtLWdybi1zcGFjZS1zKTtcblxuICBkaXNwbGF5OiBibG9jaztcbiAgb3BhY2l0eTogMDtcbiAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIGhlaWdodDogMWxoOyAvLyBwcmV2ZW50IGhlaWdodCBjb2xsYXBzZVxuICBtaW4td2lkdGg6ICR7KHsgcHJlZml4V2lkdGggfSkgPT5cbiAgICBCb29sZWFuKHByZWZpeFdpZHRoKVxuICAgICAgPyBgJHtwcmVmaXhXaWR0aCArIDF9cHhgIC8vIGVub3VnaCB3aWR0aCBzbyB0aGUgdGV4dCBjdXJzb3IgaXMgdmlzaWJsZVxuICAgICAgOiBgMXB4YH07XG4gICR7KHsgaXNUYWJ1bGFyIH0pID0+IGlzVGFidWxhciAmJiBgZm9udC1mZWF0dXJlLXNldHRpbmdzOiAndG51bSdgfTtcbmA7XG5cbmNvbnN0IHByZWZpeEdhcCA9ICcwLjNlbSc7XG5cbmNvbnN0IElucHV0UHJlZml4ID0gc3R5bGVkLnNwYW5gXG4gIGRpc3BsYXk6IGJsb2NrO1xuICBjb2xvcjogdmFyKC0tZ3JuLWNvbG9yLWNvbnRlbnQyKTtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICB0b3A6IDA7XG4gIGJvdHRvbTogMDtcbiAgbWFyZ2luOiBhdXRvO1xuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBwYWRkaW5nLXJpZ2h0OiAke3ByZWZpeEdhcH07XG4gIHBvaW50ZXItZXZlbnRzOiBub25lO1xuYDtcblxuY29uc3QgSG9sZGVyUHJlZml4ID0gc3R5bGVkLnNwYW5gXG4gIHBhZGRpbmctcmlnaHQ6ICR7cHJlZml4R2FwfTtcbmA7XG5cbmV4cG9ydCBjb25zdCBHaG9zdElucHV0ID0gUmVhY3QuZm9yd2FyZFJlZihmdW5jdGlvbiBUZXh0SW5wdXQoXG4gIHsgdmFsdWUsIHBsYWNlaG9sZGVyLCBpZCwgdHlwZSA9ICd0ZXh0JywgcHJlZml4LCBpc1RhYnVsYXIgPSB0cnVlLCBoYXNFbGxpcHNpcywgLi4ucHJvcHMgfSxcbiAgcmVmLFxuKSB7XG4gIGNvbnN0IHByZWZpeFJlZiA9IHVzZVJlZihudWxsKTtcbiAgY29uc3QgW3ByZWZpeFdpZHRoLCBzZXRQcmVmaXhXaWR0aF0gPSB1c2VTdGF0ZSgwKTtcblxuICBjb25zdCBwcmVmaXhSZWZXaWR0aCA9IHVzZVdpZHRoKHByZWZpeFJlZik7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoQm9vbGVhbihwcmVmaXgpKSB7XG4gICAgICBzZXRQcmVmaXhXaWR0aChwcmVmaXhSZWZXaWR0aCk7XG4gICAgfVxuICB9LCBbcHJlZml4V2lkdGhdKTtcblxuICByZXR1cm4gKFxuICAgIDxCb3ggcG9zaXRpb249XCJyZWxhdGl2ZVwiIHdpZHRoPVwiZml0LWNvbnRlbnRcIiBtYXhXaWR0aD1cIjEwMCVcIj5cbiAgICAgIHtwcmVmaXggJiYgPElucHV0UHJlZml4IHJlZj17cHJlZml4UmVmfT57cHJlZml4fTwvSW5wdXRQcmVmaXg+fVxuICAgICAgPElucHV0RmllbGRcbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIHR5cGU9e3R5cGV9XG4gICAgICAgIGlkPXtpZH1cbiAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICBwbGFjZWhvbGRlcj17cGxhY2Vob2xkZXJ9XG4gICAgICAgIHByZWZpeFdpZHRoPXtwcmVmaXhXaWR0aH1cbiAgICAgICAgaXNUYWJ1bGFyPXtpc1RhYnVsYXJ9XG4gICAgICAgIGhhc0VsbGlwc2lzPXtoYXNFbGxpcHNpc31cbiAgICAgICAgey4uLnByb3BzfVxuICAgICAgLz5cbiAgICAgIDxIb2xkZXIgcHJlZml4V2lkdGg9e3ByZWZpeFdpZHRofSBpc1RhYnVsYXI9e2lzVGFidWxhcn0+XG4gICAgICAgIHtwcmVmaXggJiYgPEhvbGRlclByZWZpeD57cHJlZml4fTwvSG9sZGVyUHJlZml4Pn1cbiAgICAgICAge3ZhbHVlID09PSAnJyB8fCB2YWx1ZSA9PSBudWxsID8gcGxhY2Vob2xkZXIgOiB2YWx1ZX1cbiAgICAgIDwvSG9sZGVyPlxuICAgIDwvQm94PlxuICApO1xufSk7XG5cbkdob3N0SW5wdXQucHJvcFR5cGVzID0ge1xuICB2YWx1ZTogUHJvcFR5cGVzLm9uZU9mVHlwZShbUHJvcFR5cGVzLnN0cmluZywgUHJvcFR5cGVzLm51bWJlcl0pLFxuICBwbGFjZWhvbGRlcjogUHJvcFR5cGVzLnN0cmluZyxcbiAgaWQ6IFByb3BUeXBlcy5zdHJpbmcsXG4gIHR5cGU6IFByb3BUeXBlcy5vbmVPZihbJ3RleHQnLCAnbnVtYmVyJ10pLFxuICBwcmVmaXg6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGlzVGFidWxhcjogUHJvcFR5cGVzLmJvb2wsXG4gIGhhc0VsbGlwc2lzOiBQcm9wVHlwZXMuYm9vbCxcbn07XG4iXX0= */"));
|
|
33
33
|
const Holder = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
34
34
|
target: "e1sllfu02"
|
|
35
35
|
} : {
|
|
@@ -46,20 +46,20 @@ const Holder = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production"
|
|
|
46
46
|
isTabular
|
|
47
47
|
} = _ref5;
|
|
48
48
|
return isTabular && "font-feature-settings: 'tnum'";
|
|
49
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RHlCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQm94IH0gZnJvbSAnLic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VXaWR0aCB9IGZyb20gJy4uL2hvb2tzJztcblxuY29uc3QgSW5wdXRGaWVsZCA9IHN0eWxlZC5pbnB1dGBcbiAgLS1wYWRkaW5nOiB2YXIoLS1ncm4tc3BhY2Utcyk7XG4gIC0tcGFkZGluZ0xlZnQ6ICR7KHsgcHJlZml4V2lkdGggfSkgPT5cbiAgICBCb29sZWFuKHByZWZpeFdpZHRoKSA/
|
|
49
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1RHlCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQm94IH0gZnJvbSAnLic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VXaWR0aCB9IGZyb20gJy4uL2hvb2tzJztcblxuY29uc3QgSW5wdXRGaWVsZCA9IHN0eWxlZC5pbnB1dGBcbiAgLS1wYWRkaW5nOiB2YXIoLS1ncm4tc3BhY2Utcyk7XG4gIC0tcGFkZGluZ0xlZnQ6ICR7KHsgcHJlZml4V2lkdGggfSkgPT5cbiAgICBCb29sZWFuKHByZWZpeFdpZHRoKSA/IGBjYWxjKCR7cHJlZml4V2lkdGh9cHggKyB2YXIoLS1wYWRkaW5nKSlgIDogJ3ZhcigtLXBhZGRpbmcpJ307XG5cbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250OiBpbmhlcml0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgYm9yZGVyOiBub25lO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHdpZHRoOiBjYWxjKDEwMCUgKyB2YXIoLS1wYWRkaW5nKSAqIDIpO1xuICBsZWZ0OiBjYWxjKC0xICogdmFyKC0tcGFkZGluZykpO1xuICBib3JkZXI6IG5vbmU7XG4gIG1hcmdpbjogYXV0bztcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCB0cmFuc3BhcmVudDtcbiAgYm9yZGVyLXJhZGl1czogdmFyKC0tZ3JuLXJhZGl1cy1zKTtcbiAgdHJhbnNpdGlvbjogYm94LXNoYWRvdyB2YXIoLS1ncm4tdHJhbnNpdGlvbi1sZWF2ZSk7XG4gIHBhZGRpbmctYmxvY2s6IDA7XG4gIHBhZGRpbmctbGVmdDogdmFyKC0tcGFkZGluZ0xlZnQpO1xuICBwYWRkaW5nLXJpZ2h0OiB2YXIoLS1wYWRkaW5nKTtcbiAgaGVpZ2h0OiBjYWxjKHZhcigtLXBhZGRpbmcpICogMiArIHZhcigtLWdybi1jYXApKTtcblxuICAkeyh7IGhhc0VsbGlwc2lzIH0pID0+IGhhc0VsbGlwc2lzICYmIGB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpc2B9O1xuICAkeyh7IGlzVGFidWxhciB9KSA9PiBpc1RhYnVsYXIgJiYgYGZvbnQtZmVhdHVyZS1zZXR0aW5nczogJ3RudW0nYH07XG5cbiAgJjpob3ZlciB7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAwIDAgMXB4IHZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3ItaG92ZXIpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWhvdmVyKTtcbiAgfVxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICAgIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWZvY3VzKTtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1hY3RpdmUpO1xuICB9XG5cbiAgJlt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1vdXRlci1zcGluLWJ1dHRvbixcbiAgJlt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG4gICAgLXdlYmtpdC1hcHBlYXJhbmNlOiBub25lO1xuICAgIG1hcmdpbjogMDtcbiAgfVxuICAmW3R5cGU9J251bWJlciddIHtcbiAgICAtbW96LWFwcGVhcmFuY2U6IHRleHRmaWVsZDtcbiAgfVxuYDtcblxuY29uc3QgSG9sZGVyID0gc3R5bGVkLmRpdmBcbiAgLS1wYWRkaW5nOiB2YXIoLS1ncm4tc3BhY2Utcyk7XG5cbiAgZGlzcGxheTogYmxvY2s7XG4gIG9wYWNpdHk6IDA7XG4gIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBoZWlnaHQ6IDFsaDsgLy8gcHJldmVudCBoZWlnaHQgY29sbGFwc2VcbiAgbWluLXdpZHRoOiAkeyh7IHByZWZpeFdpZHRoIH0pID0+XG4gICAgQm9vbGVhbihwcmVmaXhXaWR0aClcbiAgICAgID8gYCR7cHJlZml4V2lkdGggKyAxfXB4YCAvLyBlbm91Z2ggd2lkdGggc28gdGhlIHRleHQgY3Vyc29yIGlzIHZpc2libGVcbiAgICAgIDogYDFweGB9O1xuICAkeyh7IGlzVGFidWxhciB9KSA9PiBpc1RhYnVsYXIgJiYgYGZvbnQtZmVhdHVyZS1zZXR0aW5nczogJ3RudW0nYH07XG5gO1xuXG5jb25zdCBwcmVmaXhHYXAgPSAnMC4zZW0nO1xuXG5jb25zdCBJbnB1dFByZWZpeCA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBibG9jaztcbiAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50Mik7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIG1hcmdpbjogYXV0bztcbiAgaGVpZ2h0OiBmaXQtY29udGVudDtcbiAgcGFkZGluZy1yaWdodDogJHtwcmVmaXhHYXB9O1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbmA7XG5cbmNvbnN0IEhvbGRlclByZWZpeCA9IHN0eWxlZC5zcGFuYFxuICBwYWRkaW5nLXJpZ2h0OiAke3ByZWZpeEdhcH07XG5gO1xuXG5leHBvcnQgY29uc3QgR2hvc3RJbnB1dCA9IFJlYWN0LmZvcndhcmRSZWYoZnVuY3Rpb24gVGV4dElucHV0KFxuICB7IHZhbHVlLCBwbGFjZWhvbGRlciwgaWQsIHR5cGUgPSAndGV4dCcsIHByZWZpeCwgaXNUYWJ1bGFyID0gdHJ1ZSwgaGFzRWxsaXBzaXMsIC4uLnByb3BzIH0sXG4gIHJlZixcbikge1xuICBjb25zdCBwcmVmaXhSZWYgPSB1c2VSZWYobnVsbCk7XG4gIGNvbnN0IFtwcmVmaXhXaWR0aCwgc2V0UHJlZml4V2lkdGhdID0gdXNlU3RhdGUoMCk7XG5cbiAgY29uc3QgcHJlZml4UmVmV2lkdGggPSB1c2VXaWR0aChwcmVmaXhSZWYpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKEJvb2xlYW4ocHJlZml4KSkge1xuICAgICAgc2V0UHJlZml4V2lkdGgocHJlZml4UmVmV2lkdGgpO1xuICAgIH1cbiAgfSwgW3ByZWZpeFdpZHRoXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8Qm94IHBvc2l0aW9uPVwicmVsYXRpdmVcIiB3aWR0aD1cImZpdC1jb250ZW50XCIgbWF4V2lkdGg9XCIxMDAlXCI+XG4gICAgICB7cHJlZml4ICYmIDxJbnB1dFByZWZpeCByZWY9e3ByZWZpeFJlZn0+e3ByZWZpeH08L0lucHV0UHJlZml4Pn1cbiAgICAgIDxJbnB1dEZpZWxkXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICB0eXBlPXt0eXBlfVxuICAgICAgICBpZD17aWR9XG4gICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICBwcmVmaXhXaWR0aD17cHJlZml4V2lkdGh9XG4gICAgICAgIGlzVGFidWxhcj17aXNUYWJ1bGFyfVxuICAgICAgICBoYXNFbGxpcHNpcz17aGFzRWxsaXBzaXN9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgIC8+XG4gICAgICA8SG9sZGVyIHByZWZpeFdpZHRoPXtwcmVmaXhXaWR0aH0gaXNUYWJ1bGFyPXtpc1RhYnVsYXJ9PlxuICAgICAgICB7cHJlZml4ICYmIDxIb2xkZXJQcmVmaXg+e3ByZWZpeH08L0hvbGRlclByZWZpeD59XG4gICAgICAgIHt2YWx1ZSA9PT0gJycgfHwgdmFsdWUgPT0gbnVsbCA/IHBsYWNlaG9sZGVyIDogdmFsdWV9XG4gICAgICA8L0hvbGRlcj5cbiAgICA8L0JveD5cbiAgKTtcbn0pO1xuXG5HaG9zdElucHV0LnByb3BUeXBlcyA9IHtcbiAgdmFsdWU6IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5udW1iZXJdKSxcbiAgcGxhY2Vob2xkZXI6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLFxuICB0eXBlOiBQcm9wVHlwZXMub25lT2YoWyd0ZXh0JywgJ251bWJlciddKSxcbiAgcHJlZml4OiBQcm9wVHlwZXMuc3RyaW5nLFxuICBpc1RhYnVsYXI6IFByb3BUeXBlcy5ib29sLFxuICBoYXNFbGxpcHNpczogUHJvcFR5cGVzLmJvb2wsXG59O1xuIl19 */"));
|
|
50
50
|
const prefixGap = '0.3em';
|
|
51
51
|
const InputPrefix = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
|
|
52
52
|
target: "e1sllfu01"
|
|
53
53
|
} : {
|
|
54
54
|
target: "e1sllfu01",
|
|
55
55
|
label: "InputPrefix"
|
|
56
|
-
})("display:block;color:var(--grn-color-content2);position:absolute;top:0;bottom:0;margin:auto;height:fit-content;padding-right:", prefixGap, ";
|
|
56
|
+
})("display:block;color:var(--grn-color-content2);position:absolute;top:0;bottom:0;margin:auto;height:fit-content;padding-right:", prefixGap, ";pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3RStCIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQm94IH0gZnJvbSAnLic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VXaWR0aCB9IGZyb20gJy4uL2hvb2tzJztcblxuY29uc3QgSW5wdXRGaWVsZCA9IHN0eWxlZC5pbnB1dGBcbiAgLS1wYWRkaW5nOiB2YXIoLS1ncm4tc3BhY2Utcyk7XG4gIC0tcGFkZGluZ0xlZnQ6ICR7KHsgcHJlZml4V2lkdGggfSkgPT5cbiAgICBCb29sZWFuKHByZWZpeFdpZHRoKSA/IGBjYWxjKCR7cHJlZml4V2lkdGh9cHggKyB2YXIoLS1wYWRkaW5nKSlgIDogJ3ZhcigtLXBhZGRpbmcpJ307XG5cbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250OiBpbmhlcml0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgYm9yZGVyOiBub25lO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHdpZHRoOiBjYWxjKDEwMCUgKyB2YXIoLS1wYWRkaW5nKSAqIDIpO1xuICBsZWZ0OiBjYWxjKC0xICogdmFyKC0tcGFkZGluZykpO1xuICBib3JkZXI6IG5vbmU7XG4gIG1hcmdpbjogYXV0bztcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCB0cmFuc3BhcmVudDtcbiAgYm9yZGVyLXJhZGl1czogdmFyKC0tZ3JuLXJhZGl1cy1zKTtcbiAgdHJhbnNpdGlvbjogYm94LXNoYWRvdyB2YXIoLS1ncm4tdHJhbnNpdGlvbi1sZWF2ZSk7XG4gIHBhZGRpbmctYmxvY2s6IDA7XG4gIHBhZGRpbmctbGVmdDogdmFyKC0tcGFkZGluZ0xlZnQpO1xuICBwYWRkaW5nLXJpZ2h0OiB2YXIoLS1wYWRkaW5nKTtcbiAgaGVpZ2h0OiBjYWxjKHZhcigtLXBhZGRpbmcpICogMiArIHZhcigtLWdybi1jYXApKTtcblxuICAkeyh7IGhhc0VsbGlwc2lzIH0pID0+IGhhc0VsbGlwc2lzICYmIGB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpc2B9O1xuICAkeyh7IGlzVGFidWxhciB9KSA9PiBpc1RhYnVsYXIgJiYgYGZvbnQtZmVhdHVyZS1zZXR0aW5nczogJ3RudW0nYH07XG5cbiAgJjpob3ZlciB7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAwIDAgMXB4IHZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3ItaG92ZXIpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWhvdmVyKTtcbiAgfVxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICAgIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWZvY3VzKTtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1hY3RpdmUpO1xuICB9XG5cbiAgJlt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1vdXRlci1zcGluLWJ1dHRvbixcbiAgJlt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG4gICAgLXdlYmtpdC1hcHBlYXJhbmNlOiBub25lO1xuICAgIG1hcmdpbjogMDtcbiAgfVxuICAmW3R5cGU9J251bWJlciddIHtcbiAgICAtbW96LWFwcGVhcmFuY2U6IHRleHRmaWVsZDtcbiAgfVxuYDtcblxuY29uc3QgSG9sZGVyID0gc3R5bGVkLmRpdmBcbiAgLS1wYWRkaW5nOiB2YXIoLS1ncm4tc3BhY2Utcyk7XG5cbiAgZGlzcGxheTogYmxvY2s7XG4gIG9wYWNpdHk6IDA7XG4gIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBoZWlnaHQ6IDFsaDsgLy8gcHJldmVudCBoZWlnaHQgY29sbGFwc2VcbiAgbWluLXdpZHRoOiAkeyh7IHByZWZpeFdpZHRoIH0pID0+XG4gICAgQm9vbGVhbihwcmVmaXhXaWR0aClcbiAgICAgID8gYCR7cHJlZml4V2lkdGggKyAxfXB4YCAvLyBlbm91Z2ggd2lkdGggc28gdGhlIHRleHQgY3Vyc29yIGlzIHZpc2libGVcbiAgICAgIDogYDFweGB9O1xuICAkeyh7IGlzVGFidWxhciB9KSA9PiBpc1RhYnVsYXIgJiYgYGZvbnQtZmVhdHVyZS1zZXR0aW5nczogJ3RudW0nYH07XG5gO1xuXG5jb25zdCBwcmVmaXhHYXAgPSAnMC4zZW0nO1xuXG5jb25zdCBJbnB1dFByZWZpeCA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBibG9jaztcbiAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50Mik7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIG1hcmdpbjogYXV0bztcbiAgaGVpZ2h0OiBmaXQtY29udGVudDtcbiAgcGFkZGluZy1yaWdodDogJHtwcmVmaXhHYXB9O1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbmA7XG5cbmNvbnN0IEhvbGRlclByZWZpeCA9IHN0eWxlZC5zcGFuYFxuICBwYWRkaW5nLXJpZ2h0OiAke3ByZWZpeEdhcH07XG5gO1xuXG5leHBvcnQgY29uc3QgR2hvc3RJbnB1dCA9IFJlYWN0LmZvcndhcmRSZWYoZnVuY3Rpb24gVGV4dElucHV0KFxuICB7IHZhbHVlLCBwbGFjZWhvbGRlciwgaWQsIHR5cGUgPSAndGV4dCcsIHByZWZpeCwgaXNUYWJ1bGFyID0gdHJ1ZSwgaGFzRWxsaXBzaXMsIC4uLnByb3BzIH0sXG4gIHJlZixcbikge1xuICBjb25zdCBwcmVmaXhSZWYgPSB1c2VSZWYobnVsbCk7XG4gIGNvbnN0IFtwcmVmaXhXaWR0aCwgc2V0UHJlZml4V2lkdGhdID0gdXNlU3RhdGUoMCk7XG5cbiAgY29uc3QgcHJlZml4UmVmV2lkdGggPSB1c2VXaWR0aChwcmVmaXhSZWYpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKEJvb2xlYW4ocHJlZml4KSkge1xuICAgICAgc2V0UHJlZml4V2lkdGgocHJlZml4UmVmV2lkdGgpO1xuICAgIH1cbiAgfSwgW3ByZWZpeFdpZHRoXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8Qm94IHBvc2l0aW9uPVwicmVsYXRpdmVcIiB3aWR0aD1cImZpdC1jb250ZW50XCIgbWF4V2lkdGg9XCIxMDAlXCI+XG4gICAgICB7cHJlZml4ICYmIDxJbnB1dFByZWZpeCByZWY9e3ByZWZpeFJlZn0+e3ByZWZpeH08L0lucHV0UHJlZml4Pn1cbiAgICAgIDxJbnB1dEZpZWxkXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICB0eXBlPXt0eXBlfVxuICAgICAgICBpZD17aWR9XG4gICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICBwcmVmaXhXaWR0aD17cHJlZml4V2lkdGh9XG4gICAgICAgIGlzVGFidWxhcj17aXNUYWJ1bGFyfVxuICAgICAgICBoYXNFbGxpcHNpcz17aGFzRWxsaXBzaXN9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgIC8+XG4gICAgICA8SG9sZGVyIHByZWZpeFdpZHRoPXtwcmVmaXhXaWR0aH0gaXNUYWJ1bGFyPXtpc1RhYnVsYXJ9PlxuICAgICAgICB7cHJlZml4ICYmIDxIb2xkZXJQcmVmaXg+e3ByZWZpeH08L0hvbGRlclByZWZpeD59XG4gICAgICAgIHt2YWx1ZSA9PT0gJycgfHwgdmFsdWUgPT0gbnVsbCA/IHBsYWNlaG9sZGVyIDogdmFsdWV9XG4gICAgICA8L0hvbGRlcj5cbiAgICA8L0JveD5cbiAgKTtcbn0pO1xuXG5HaG9zdElucHV0LnByb3BUeXBlcyA9IHtcbiAgdmFsdWU6IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5udW1iZXJdKSxcbiAgcGxhY2Vob2xkZXI6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLFxuICB0eXBlOiBQcm9wVHlwZXMub25lT2YoWyd0ZXh0JywgJ251bWJlciddKSxcbiAgcHJlZml4OiBQcm9wVHlwZXMuc3RyaW5nLFxuICBpc1RhYnVsYXI6IFByb3BUeXBlcy5ib29sLFxuICBoYXNFbGxpcHNpczogUHJvcFR5cGVzLmJvb2wsXG59O1xuIl19 */"));
|
|
57
57
|
const HolderPrefix = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
|
|
58
58
|
target: "e1sllfu00"
|
|
59
59
|
} : {
|
|
60
60
|
target: "e1sllfu00",
|
|
61
61
|
label: "HolderPrefix"
|
|
62
|
-
})("padding-right:", prefixGap, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
62
|
+
})("padding-right:", prefixGap, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRmdDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2dob3N0LWlucHV0LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgQm94IH0gZnJvbSAnLic7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB1c2VXaWR0aCB9IGZyb20gJy4uL2hvb2tzJztcblxuY29uc3QgSW5wdXRGaWVsZCA9IHN0eWxlZC5pbnB1dGBcbiAgLS1wYWRkaW5nOiB2YXIoLS1ncm4tc3BhY2Utcyk7XG4gIC0tcGFkZGluZ0xlZnQ6ICR7KHsgcHJlZml4V2lkdGggfSkgPT5cbiAgICBCb29sZWFuKHByZWZpeFdpZHRoKSA/IGBjYWxjKCR7cHJlZml4V2lkdGh9cHggKyB2YXIoLS1wYWRkaW5nKSlgIDogJ3ZhcigtLXBhZGRpbmcpJ307XG5cbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGRpc3BsYXk6IGJsb2NrO1xuICBmb250OiBpbmhlcml0O1xuICBjb2xvcjogaW5oZXJpdDtcbiAgYm9yZGVyOiBub25lO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHdpZHRoOiBjYWxjKDEwMCUgKyB2YXIoLS1wYWRkaW5nKSAqIDIpO1xuICBsZWZ0OiBjYWxjKC0xICogdmFyKC0tcGFkZGluZykpO1xuICBib3JkZXI6IG5vbmU7XG4gIG1hcmdpbjogYXV0bztcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCB0cmFuc3BhcmVudDtcbiAgYm9yZGVyLXJhZGl1czogdmFyKC0tZ3JuLXJhZGl1cy1zKTtcbiAgdHJhbnNpdGlvbjogYm94LXNoYWRvdyB2YXIoLS1ncm4tdHJhbnNpdGlvbi1sZWF2ZSk7XG4gIHBhZGRpbmctYmxvY2s6IDA7XG4gIHBhZGRpbmctbGVmdDogdmFyKC0tcGFkZGluZ0xlZnQpO1xuICBwYWRkaW5nLXJpZ2h0OiB2YXIoLS1wYWRkaW5nKTtcbiAgaGVpZ2h0OiBjYWxjKHZhcigtLXBhZGRpbmcpICogMiArIHZhcigtLWdybi1jYXApKTtcblxuICAkeyh7IGhhc0VsbGlwc2lzIH0pID0+IGhhc0VsbGlwc2lzICYmIGB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpc2B9O1xuICAkeyh7IGlzVGFidWxhciB9KSA9PiBpc1RhYnVsYXIgJiYgYGZvbnQtZmVhdHVyZS1zZXR0aW5nczogJ3RudW0nYH07XG5cbiAgJjpob3ZlciB7XG4gICAgYm94LXNoYWRvdzogaW5zZXQgMCAwIDAgMXB4IHZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3ItaG92ZXIpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWhvdmVyKTtcbiAgfVxuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiBub25lO1xuICAgIGJveC1zaGFkb3c6IGluc2V0IDAgMCAwIDFweCB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWZvY3VzKTtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1hY3RpdmUpO1xuICB9XG5cbiAgJlt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1vdXRlci1zcGluLWJ1dHRvbixcbiAgJlt0eXBlPSdudW1iZXInXTo6LXdlYmtpdC1pbm5lci1zcGluLWJ1dHRvbiB7XG4gICAgLXdlYmtpdC1hcHBlYXJhbmNlOiBub25lO1xuICAgIG1hcmdpbjogMDtcbiAgfVxuICAmW3R5cGU9J251bWJlciddIHtcbiAgICAtbW96LWFwcGVhcmFuY2U6IHRleHRmaWVsZDtcbiAgfVxuYDtcblxuY29uc3QgSG9sZGVyID0gc3R5bGVkLmRpdmBcbiAgLS1wYWRkaW5nOiB2YXIoLS1ncm4tc3BhY2Utcyk7XG5cbiAgZGlzcGxheTogYmxvY2s7XG4gIG9wYWNpdHk6IDA7XG4gIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICBoZWlnaHQ6IDFsaDsgLy8gcHJldmVudCBoZWlnaHQgY29sbGFwc2VcbiAgbWluLXdpZHRoOiAkeyh7IHByZWZpeFdpZHRoIH0pID0+XG4gICAgQm9vbGVhbihwcmVmaXhXaWR0aClcbiAgICAgID8gYCR7cHJlZml4V2lkdGggKyAxfXB4YCAvLyBlbm91Z2ggd2lkdGggc28gdGhlIHRleHQgY3Vyc29yIGlzIHZpc2libGVcbiAgICAgIDogYDFweGB9O1xuICAkeyh7IGlzVGFidWxhciB9KSA9PiBpc1RhYnVsYXIgJiYgYGZvbnQtZmVhdHVyZS1zZXR0aW5nczogJ3RudW0nYH07XG5gO1xuXG5jb25zdCBwcmVmaXhHYXAgPSAnMC4zZW0nO1xuXG5jb25zdCBJbnB1dFByZWZpeCA9IHN0eWxlZC5zcGFuYFxuICBkaXNwbGF5OiBibG9jaztcbiAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50Mik7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAwO1xuICBib3R0b206IDA7XG4gIG1hcmdpbjogYXV0bztcbiAgaGVpZ2h0OiBmaXQtY29udGVudDtcbiAgcGFkZGluZy1yaWdodDogJHtwcmVmaXhHYXB9O1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbmA7XG5cbmNvbnN0IEhvbGRlclByZWZpeCA9IHN0eWxlZC5zcGFuYFxuICBwYWRkaW5nLXJpZ2h0OiAke3ByZWZpeEdhcH07XG5gO1xuXG5leHBvcnQgY29uc3QgR2hvc3RJbnB1dCA9IFJlYWN0LmZvcndhcmRSZWYoZnVuY3Rpb24gVGV4dElucHV0KFxuICB7IHZhbHVlLCBwbGFjZWhvbGRlciwgaWQsIHR5cGUgPSAndGV4dCcsIHByZWZpeCwgaXNUYWJ1bGFyID0gdHJ1ZSwgaGFzRWxsaXBzaXMsIC4uLnByb3BzIH0sXG4gIHJlZixcbikge1xuICBjb25zdCBwcmVmaXhSZWYgPSB1c2VSZWYobnVsbCk7XG4gIGNvbnN0IFtwcmVmaXhXaWR0aCwgc2V0UHJlZml4V2lkdGhdID0gdXNlU3RhdGUoMCk7XG5cbiAgY29uc3QgcHJlZml4UmVmV2lkdGggPSB1c2VXaWR0aChwcmVmaXhSZWYpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKEJvb2xlYW4ocHJlZml4KSkge1xuICAgICAgc2V0UHJlZml4V2lkdGgocHJlZml4UmVmV2lkdGgpO1xuICAgIH1cbiAgfSwgW3ByZWZpeFdpZHRoXSk7XG5cbiAgcmV0dXJuIChcbiAgICA8Qm94IHBvc2l0aW9uPVwicmVsYXRpdmVcIiB3aWR0aD1cImZpdC1jb250ZW50XCIgbWF4V2lkdGg9XCIxMDAlXCI+XG4gICAgICB7cHJlZml4ICYmIDxJbnB1dFByZWZpeCByZWY9e3ByZWZpeFJlZn0+e3ByZWZpeH08L0lucHV0UHJlZml4Pn1cbiAgICAgIDxJbnB1dEZpZWxkXG4gICAgICAgIHJlZj17cmVmfVxuICAgICAgICB0eXBlPXt0eXBlfVxuICAgICAgICBpZD17aWR9XG4gICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICBwcmVmaXhXaWR0aD17cHJlZml4V2lkdGh9XG4gICAgICAgIGlzVGFidWxhcj17aXNUYWJ1bGFyfVxuICAgICAgICBoYXNFbGxpcHNpcz17aGFzRWxsaXBzaXN9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgIC8+XG4gICAgICA8SG9sZGVyIHByZWZpeFdpZHRoPXtwcmVmaXhXaWR0aH0gaXNUYWJ1bGFyPXtpc1RhYnVsYXJ9PlxuICAgICAgICB7cHJlZml4ICYmIDxIb2xkZXJQcmVmaXg+e3ByZWZpeH08L0hvbGRlclByZWZpeD59XG4gICAgICAgIHt2YWx1ZSA9PT0gJycgfHwgdmFsdWUgPT0gbnVsbCA/IHBsYWNlaG9sZGVyIDogdmFsdWV9XG4gICAgICA8L0hvbGRlcj5cbiAgICA8L0JveD5cbiAgKTtcbn0pO1xuXG5HaG9zdElucHV0LnByb3BUeXBlcyA9IHtcbiAgdmFsdWU6IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5udW1iZXJdKSxcbiAgcGxhY2Vob2xkZXI6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLFxuICB0eXBlOiBQcm9wVHlwZXMub25lT2YoWyd0ZXh0JywgJ251bWJlciddKSxcbiAgcHJlZml4OiBQcm9wVHlwZXMuc3RyaW5nLFxuICBpc1RhYnVsYXI6IFByb3BUeXBlcy5ib29sLFxuICBoYXNFbGxpcHNpczogUHJvcFR5cGVzLmJvb2wsXG59O1xuIl19 */"));
|
|
63
63
|
export const GhostInput = /*#__PURE__*/React.forwardRef(function TextInput(_ref6, ref) {
|
|
64
64
|
let {
|
|
65
65
|
value,
|
|
@@ -26,7 +26,7 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
|
|
|
26
26
|
size
|
|
27
27
|
} = _ref2;
|
|
28
28
|
return "var(--grn-textbox-radius-".concat(size, ")");
|
|
29
|
-
}, ";display:flex;border-radius:var(--radius);padding:var(--inset);background:var(--grn-color-
|
|
29
|
+
}, ";display:flex;border-radius:var(--radius);padding:var(--inset);background:var(--grn-color-overlay);", p => !p.hasFullWidth && "width: fit-content", ";", p => p.hasFullWidth && "\n .IconToggle {\n flex: 1 0 0;\n }\n ", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2ljb24tdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRMEIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvaWNvbi10b2dnbGUuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IgfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4nO1xuaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLS1pbnNldDogMnB4O1xuICAtLWhlaWdodDogJHsoeyBzaXplIH0pID0+IGBjYWxjKHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC0ke3NpemV9KSAtIHZhcigtLWluc2V0KSAqIDIpYH07XG4gIC0tcmFkaXVzOiAkeyh7IHNpemUgfSkgPT4gYHZhcigtLWdybi10ZXh0Ym94LXJhZGl1cy0ke3NpemV9KWB9O1xuXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGJvcmRlci1yYWRpdXM6IHZhcigtLXJhZGl1cyk7XG4gIHBhZGRpbmc6IHZhcigtLWluc2V0KTtcbiAgYmFja2dyb3VuZDogdmFyKC0tZ3JuLWNvbG9yLW92ZXJsYXkpO1xuXG4gICR7cCA9PiAhcC5oYXNGdWxsV2lkdGggJiYgYHdpZHRoOiBmaXQtY29udGVudGB9O1xuICAke3AgPT5cbiAgICBwLmhhc0Z1bGxXaWR0aCAmJlxuICAgIGBcbiAgICAuSWNvblRvZ2dsZSB7XG4gICAgICBmbGV4OiAxIDAgMDtcbiAgICB9XG4gIGB9XG5gO1xuXG5jb25zdCBJdGVtV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7c3R5bGVzLmJ1dHRvblJlc2V0fTtcbiAgLS1ncm4tY29sb3ItaWNvbjogY3VycmVudENvbG9yO1xuXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMDtcbiAgbWluLXdpZHRoOiB2YXIoLS1oZWlnaHQpO1xuICBoZWlnaHQ6IHZhcigtLWhlaWdodCk7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgY29sb3I6ICR7Z2V0Q29sb3IoJ2NvbnRlbnQyJyl9O1xuICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1sZWF2ZSk7XG4gIGJvcmRlci1yYWRpdXM6IGNhbGModmFyKC0tcmFkaXVzKSAtIHZhcigtLWluc2V0KSk7XG5cbiAgJHsoeyBpc0FjdGl2ZSB9KSA9PlxuICAgIGlzQWN0aXZlICYmXG4gICAgYFxuICAgIGNvbG9yOiAke2dldENvbG9yKCdjb250ZW50Jyl9O1xuICAgIGJhY2tncm91bmQ6ICR7Z2V0Q29sb3IoJ3NoYWRlMScpfTtcbiAgYH07XG5cbiAgJjpob3ZlciB7XG4gICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24taG92ZXIpO1xuICAgICR7KHsgaXNBY3RpdmUgfSkgPT5cbiAgICAgICFpc0FjdGl2ZSAmJlxuICAgICAgYFxuICAgICAgY29sb3I6ICR7Z2V0Q29sb3IoJ2NvbnRlbnQnKX07XG4gICAgYH07XG4gIH1cblxuICAuSWNvbiB7XG4gICAgdHJhbnNpdGlvbjogdW5zZXQ7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBJY29uVG9nZ2xlID0gZm9yd2FyZFJlZihmdW5jdGlvbiBJY29uVG9nZ2xlKFxuICB7IGNoaWxkcmVuLCBpY29uLCBpc0FjdGl2ZSwgb25DbGljaywgLi4ucHJvcHMgfSxcbiAgcmVmLFxuKSB7XG4gIHJldHVybiAoXG4gICAgPEl0ZW1XcmFwcGVyXG4gICAgICByZWY9e3JlZn1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgY2xhc3NOYW1lPVwiSWNvblRvZ2dsZVwiXG4gICAgICBpc0FjdGl2ZT17aXNBY3RpdmV9XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgey4uLnByb3BzfVxuICAgID5cbiAgICAgIHtpY29uICYmIDxJY29uIGljb249e2ljb259IC8+fVxuICAgICAge2NoaWxkcmVuICYmIGNoaWxkcmVufVxuICAgIDwvSXRlbVdyYXBwZXI+XG4gICk7XG59KTtcblxuZXhwb3J0IGNvbnN0IEljb25Ub2dnbGVHcm91cCA9IGZvcndhcmRSZWYoZnVuY3Rpb24gSWNvblRvZ2dsZUdyb3VwKFxuICB7IGNoaWxkcmVuLCBzaXplID0gJ20nLCBoYXNGdWxsV2lkdGgsIC4uLnByb3BzIH0sXG4gIHJlZixcbikge1xuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyIHJlZj17cmVmfSBzaXplPXtzaXplfSBoYXNGdWxsV2lkdGg9e2hhc0Z1bGxXaWR0aH0gey4uLnByb3BzfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1dyYXBwZXI+XG4gICk7XG59KTtcblxuSWNvblRvZ2dsZUdyb3VwLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuSWNvblRvZ2dsZS5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaWNvbjogdHlwZXMuaWNvbixcbiAgaXNBY3RpdmU6IFByb3BUeXBlcy5ib29sLFxuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbn07XG4iXX0= */"));
|
|
30
30
|
const ItemWrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
|
|
31
31
|
target: "e9umpvt0"
|
|
32
32
|
} : {
|
|
@@ -42,7 +42,7 @@ const ItemWrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "pro
|
|
|
42
42
|
isActive
|
|
43
43
|
} = _ref4;
|
|
44
44
|
return !isActive && "\n color: ".concat(getColor('content'), ";\n ");
|
|
45
|
-
}, ";}.Icon{transition:unset;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2ljb24tdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QmlDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2ljb24tdG9nZ2xlLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IEljb24gfSBmcm9tICcuJztcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgc3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC0taW5zZXQ6IDJweDtcbiAgLS1oZWlnaHQ6ICR7KHsgc2l6ZSB9KSA9PiBgY2FsYyh2YXIoLS1ncm4tdGV4dGJveC1oZWlnaHQtJHtzaXplfSkgLSB2YXIoLS1pbnNldCkgKiAyKWB9O1xuICAtLXJhZGl1czogJHsoeyBzaXplIH0pID0+
|
|
45
|
+
}, ";}.Icon{transition:unset;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL2ljb24tdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0QmlDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL2ljb24tdG9nZ2xlLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCB7IEljb24gfSBmcm9tICcuJztcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IHR5cGVzIH0gZnJvbSAnLi4vdHlwZXMnO1xuaW1wb3J0IHsgc3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC0taW5zZXQ6IDJweDtcbiAgLS1oZWlnaHQ6ICR7KHsgc2l6ZSB9KSA9PiBgY2FsYyh2YXIoLS1ncm4tdGV4dGJveC1oZWlnaHQtJHtzaXplfSkgLSB2YXIoLS1pbnNldCkgKiAyKWB9O1xuICAtLXJhZGl1czogJHsoeyBzaXplIH0pID0+IGB2YXIoLS1ncm4tdGV4dGJveC1yYWRpdXMtJHtzaXplfSlgfTtcblxuICBkaXNwbGF5OiBmbGV4O1xuICBib3JkZXItcmFkaXVzOiB2YXIoLS1yYWRpdXMpO1xuICBwYWRkaW5nOiB2YXIoLS1pbnNldCk7XG4gIGJhY2tncm91bmQ6IHZhcigtLWdybi1jb2xvci1vdmVybGF5KTtcblxuICAke3AgPT4gIXAuaGFzRnVsbFdpZHRoICYmIGB3aWR0aDogZml0LWNvbnRlbnRgfTtcbiAgJHtwID0+XG4gICAgcC5oYXNGdWxsV2lkdGggJiZcbiAgICBgXG4gICAgLkljb25Ub2dnbGUge1xuICAgICAgZmxleDogMSAwIDA7XG4gICAgfVxuICBgfVxuYDtcblxuY29uc3QgSXRlbVdyYXBwZXIgPSBzdHlsZWQuYnV0dG9uYFxuICAke3N0eWxlcy5idXR0b25SZXNldH07XG4gIC0tZ3JuLWNvbG9yLWljb246IGN1cnJlbnRDb2xvcjtcblxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDA7XG4gIG1pbi13aWR0aDogdmFyKC0taGVpZ2h0KTtcbiAgaGVpZ2h0OiB2YXIoLS1oZWlnaHQpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGNvbG9yOiAke2dldENvbG9yKCdjb250ZW50MicpfTtcbiAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tbGVhdmUpO1xuICBib3JkZXItcmFkaXVzOiBjYWxjKHZhcigtLXJhZGl1cykgLSB2YXIoLS1pbnNldCkpO1xuXG4gICR7KHsgaXNBY3RpdmUgfSkgPT5cbiAgICBpc0FjdGl2ZSAmJlxuICAgIGBcbiAgICBjb2xvcjogJHtnZXRDb2xvcignY29udGVudCcpfTtcbiAgICBiYWNrZ3JvdW5kOiAke2dldENvbG9yKCdzaGFkZTEnKX07XG4gIGB9O1xuXG4gICY6aG92ZXIge1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWhvdmVyKTtcbiAgICAkeyh7IGlzQWN0aXZlIH0pID0+XG4gICAgICAhaXNBY3RpdmUgJiZcbiAgICAgIGBcbiAgICAgIGNvbG9yOiAke2dldENvbG9yKCdjb250ZW50Jyl9O1xuICAgIGB9O1xuICB9XG5cbiAgLkljb24ge1xuICAgIHRyYW5zaXRpb246IHVuc2V0O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgSWNvblRvZ2dsZSA9IGZvcndhcmRSZWYoZnVuY3Rpb24gSWNvblRvZ2dsZShcbiAgeyBjaGlsZHJlbiwgaWNvbiwgaXNBY3RpdmUsIG9uQ2xpY2ssIC4uLnByb3BzIH0sXG4gIHJlZixcbikge1xuICByZXR1cm4gKFxuICAgIDxJdGVtV3JhcHBlclxuICAgICAgcmVmPXtyZWZ9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIGNsYXNzTmFtZT1cIkljb25Ub2dnbGVcIlxuICAgICAgaXNBY3RpdmU9e2lzQWN0aXZlfVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICAgIHsuLi5wcm9wc31cbiAgICA+XG4gICAgICB7aWNvbiAmJiA8SWNvbiBpY29uPXtpY29ufSAvPn1cbiAgICAgIHtjaGlsZHJlbiAmJiBjaGlsZHJlbn1cbiAgICA8L0l0ZW1XcmFwcGVyPlxuICApO1xufSk7XG5cbmV4cG9ydCBjb25zdCBJY29uVG9nZ2xlR3JvdXAgPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIEljb25Ub2dnbGVHcm91cChcbiAgeyBjaGlsZHJlbiwgc2l6ZSA9ICdtJywgaGFzRnVsbFdpZHRoLCAuLi5wcm9wcyB9LFxuICByZWYsXG4pIHtcbiAgcmV0dXJuIChcbiAgICA8V3JhcHBlciByZWY9e3JlZn0gc2l6ZT17c2l6ZX0gaGFzRnVsbFdpZHRoPXtoYXNGdWxsV2lkdGh9IHsuLi5wcm9wc30+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9XcmFwcGVyPlxuICApO1xufSk7XG5cbkljb25Ub2dnbGVHcm91cC5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbn07XG5cbkljb25Ub2dnbGUucHJvcFR5cGVzID0ge1xuICBjaGlsZHJlbjogUHJvcFR5cGVzLm5vZGUsXG4gIGljb246IHR5cGVzLmljb24sXG4gIGlzQWN0aXZlOiBQcm9wVHlwZXMuYm9vbCxcbiAgb25DbGljazogUHJvcFR5cGVzLmZ1bmMsXG59O1xuIl19 */"));
|
|
46
46
|
export const IconToggle = /*#__PURE__*/forwardRef(function IconToggle(_ref5, ref) {
|
|
47
47
|
let {
|
|
48
48
|
children,
|
package/es/components/select.js
CHANGED
|
@@ -12,7 +12,7 @@ import React, { forwardRef, Fragment, useMemo } from 'react';
|
|
|
12
12
|
import { Arrange, Box, Icon, Text, TextButton } from '.';
|
|
13
13
|
import { IconChevronDown } from '../icons';
|
|
14
14
|
import { Listbox } from '@headlessui/react';
|
|
15
|
-
import { getColor,
|
|
15
|
+
import { getColor, getWeight } from '../utilities';
|
|
16
16
|
import { defaultProps, types } from '../types';
|
|
17
17
|
import { FieldClearButton, fieldDisabledStyles, FieldHint, FieldLabel, MenuCard, MenuCardTransition, MenuItem, styles } from '../foundational';
|
|
18
18
|
import { MenuItemDivider, useMenuPosition } from '../foundational/menu';
|
|
@@ -38,11 +38,16 @@ const TriggerButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "p
|
|
|
38
38
|
size
|
|
39
39
|
} = _ref3;
|
|
40
40
|
return "var(--grn-textbox-height-".concat(size, ")");
|
|
41
|
-
}, ";border-radius:", getRadius('s'), ";width:100%;text-align:left;&:hover{border-color:var(--grn-field-border-color-hover);}&[disabled]{", fieldDisabledStyles, ";cursor:default;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAqBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'var(--grn-field-background)')};\n  padding-block: 0;\n  padding-inline: ${({ size }) => `var(--grn-field-paddingX-${size})`};\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: ${({ size }) => `var(--grn-textbox-height-${size})`};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(function Trigger(\n  { children, variant = 'box', backgroundColor, onClear, hasClearButton, size = 'm', ...props },\n  ref,\n) {\n  return (\n    <>\n      {variant === 'box' && (\n        <TriggerButton\n          ref={ref}\n          type=\"button\"\n          backgroundColor={backgroundColor}\n          size={size}\n          {...props}\n        >\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  );\n});\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n  size,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          size={size}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n  size = 'm',\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n              size={size}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
42
|
-
const ClearButton = _ref4 => {
|
|
41
|
+
}, ";border-radius:", _ref4 => {
|
|
43
42
|
let {
|
|
44
|
-
|
|
43
|
+
size
|
|
45
44
|
} = _ref4;
|
|
45
|
+
return "var(--grn-textbox-radius-".concat(size, ")");
|
|
46
|
+
}, ";width:100%;text-align:left;&:hover{border-color:var(--grn-field-border-color-hover);}&[disabled]{", fieldDisabledStyles, ";cursor:default;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAqBmC","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'var(--grn-field-background)')};\n  padding-block: 0;\n  padding-inline: ${({ size }) => `var(--grn-field-paddingX-${size})`};\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: ${({ size }) => `var(--grn-textbox-height-${size})`};\n  border-radius: ${({ size }) => `var(--grn-textbox-radius-${size})`};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(function Trigger(\n  { children, variant = 'box', backgroundColor, onClear, hasClearButton, size = 'm', ...props },\n  ref,\n) {\n  return (\n    <>\n      {variant === 'box' && (\n        <TriggerButton\n          ref={ref}\n          type=\"button\"\n          backgroundColor={backgroundColor}\n          size={size}\n          {...props}\n        >\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  );\n});\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n  size,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          size={size}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n  size = 'm',\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n              size={size}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */"));
|
|
47
|
+
const ClearButton = _ref5 => {
|
|
48
|
+
let {
|
|
49
|
+
onClick
|
|
50
|
+
} = _ref5;
|
|
46
51
|
const handleClear = e => {
|
|
47
52
|
e.stopPropagation();
|
|
48
53
|
onClick();
|
|
@@ -52,7 +57,7 @@ const ClearButton = _ref4 => {
|
|
|
52
57
|
tag: "span"
|
|
53
58
|
});
|
|
54
59
|
};
|
|
55
|
-
const Trigger = /*#__PURE__*/forwardRef(function Trigger(
|
|
60
|
+
const Trigger = /*#__PURE__*/forwardRef(function Trigger(_ref6, ref) {
|
|
56
61
|
let {
|
|
57
62
|
children,
|
|
58
63
|
variant = 'box',
|
|
@@ -60,8 +65,8 @@ const Trigger = /*#__PURE__*/forwardRef(function Trigger(_ref5, ref) {
|
|
|
60
65
|
onClear,
|
|
61
66
|
hasClearButton,
|
|
62
67
|
size = 'm'
|
|
63
|
-
} =
|
|
64
|
-
props = _objectWithoutProperties(
|
|
68
|
+
} = _ref6,
|
|
69
|
+
props = _objectWithoutProperties(_ref6, _excluded);
|
|
65
70
|
return ___EmotionJSX(React.Fragment, null, variant === 'box' && ___EmotionJSX(TriggerButton, _extends({
|
|
66
71
|
ref: ref,
|
|
67
72
|
type: "button",
|
|
@@ -94,7 +99,7 @@ const getTriggerContent = (isMultiple, selected, placeholder) => {
|
|
|
94
99
|
}
|
|
95
100
|
return selected.content;
|
|
96
101
|
};
|
|
97
|
-
const SelectButton =
|
|
102
|
+
const SelectButton = _ref7 => {
|
|
98
103
|
let {
|
|
99
104
|
customTrigger,
|
|
100
105
|
variant,
|
|
@@ -104,7 +109,7 @@ const SelectButton = _ref6 => {
|
|
|
104
109
|
backgroundColor,
|
|
105
110
|
onClear,
|
|
106
111
|
size
|
|
107
|
-
} =
|
|
112
|
+
} = _ref7;
|
|
108
113
|
const props = {
|
|
109
114
|
variant,
|
|
110
115
|
children: getTriggerContent(isMultiple, selected, placeholder)
|
|
@@ -132,25 +137,25 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
|
|
|
132
137
|
} : {
|
|
133
138
|
name: "wowqs1",
|
|
134
139
|
styles: "min-width:0px",
|
|
135
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAoIuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getRadius, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'var(--grn-field-background)')};\n  padding-block: 0;\n  padding-inline: ${({ size }) => `var(--grn-field-paddingX-${size})`};\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: ${({ size }) => `var(--grn-textbox-height-${size})`};\n  border-radius: ${getRadius('s')};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(function Trigger(\n  { children, variant = 'box', backgroundColor, onClear, hasClearButton, size = 'm', ...props },\n  ref,\n) {\n  return (\n    <>\n      {variant === 'box' && (\n        <TriggerButton\n          ref={ref}\n          type=\"button\"\n          backgroundColor={backgroundColor}\n          size={size}\n          {...props}\n        >\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  );\n});\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n  size,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          size={size}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n  size = 'm',\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n              size={size}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */",
|
|
140
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAoIuB","file":"../../src/components/select.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo } from 'react';\nimport styled from '@emotion/styled';\nimport { Arrange, Box, Icon, Text, TextButton } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Listbox } from '@headlessui/react';\nimport { getColor, getWeight } from '../utilities';\nimport { defaultProps, types } from '../types';\nimport {\n  FieldClearButton,\n  fieldDisabledStyles,\n  FieldHint,\n  FieldLabel,\n  MenuCard,\n  MenuCardTransition,\n  MenuItem,\n  styles,\n} from '../foundational';\nimport { MenuItemDivider, useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\n\nconst TriggerButton = styled.button`\n  ${styles.buttonReset};\n  ${styles.transitions};\n\n  color: inherit;\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  border: none;\n  background: ${({ backgroundColor }) =>\n    getColor(backgroundColor ? backgroundColor : 'var(--grn-field-background)')};\n  padding-block: 0;\n  padding-inline: ${({ size }) => `var(--grn-field-paddingX-${size})`};\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: ${({ size }) => `var(--grn-textbox-height-${size})`};\n  border-radius: ${({ size }) => `var(--grn-textbox-radius-${size})`};\n  width: 100%;\n  text-align: left;\n\n  &:hover {\n    border-color: var(--grn-field-border-color-hover);\n  }\n\n  &[disabled] {\n    ${fieldDisabledStyles};\n    cursor: default;\n  }\n`;\n\nconst ClearButton = ({ onClick }) => {\n  const handleClear = e => {\n    e.stopPropagation();\n    onClick();\n  };\n  return <FieldClearButton onClick={e => handleClear(e)} tag=\"span\" />;\n};\n\nconst Trigger = forwardRef(function Trigger(\n  { children, variant = 'box', backgroundColor, onClear, hasClearButton, size = 'm', ...props },\n  ref,\n) {\n  return (\n    <>\n      {variant === 'box' && (\n        <TriggerButton\n          ref={ref}\n          type=\"button\"\n          backgroundColor={backgroundColor}\n          size={size}\n          {...props}\n        >\n          <Text hasEllipsis>{children}</Text>\n          <Arrange marginLeft=\"auto\" gap=\"xs\">\n            {hasClearButton && <ClearButton onClick={onClear} />}\n            <Icon icon={<IconChevronDown />} />\n          </Arrange>\n        </TriggerButton>\n      )}\n      {variant === 'text' && (\n        <TextButton ref={ref} icon={<IconChevronDown />} iconPosition=\"right\" {...props}>\n          {children}\n        </TextButton>\n      )}\n    </>\n  );\n});\n\nconst getTriggerContent = (isMultiple, selected, placeholder) => {\n  if (!selected) {\n    if (placeholder) return <Text color=\"var(--grn-field-placeholder-color)\">{placeholder}</Text>;\n    return null;\n  }\n  if (isMultiple) {\n    return selected.map(option => option.content).join(', ');\n  }\n  return selected.content;\n};\n\nconst SelectButton = ({\n  customTrigger,\n  variant,\n  isMultiple,\n  selected,\n  placeholder,\n  backgroundColor,\n  onClear,\n  size,\n}) => {\n  const props = {\n    variant,\n    children: getTriggerContent(isMultiple, selected, placeholder),\n  };\n  const hasClearButton = onClear && Boolean(selected);\n  return (\n    <Listbox.Button as={Fragment}>\n      {customTrigger ? (\n        customTrigger({ props })\n      ) : (\n        <Trigger\n          backgroundColor={backgroundColor}\n          onClear={onClear}\n          hasClearButton={hasClearButton}\n          size={size}\n          {...props}\n        />\n      )}\n    </Listbox.Button>\n  );\n};\n\nconst Root = styled.div`\n  min-width: 0px;\n`;\n\nconst SelectMenuOption = ({\n  option,\n  isSelected,\n  menuItemsHaveEllipsis,\n  allowMultiple,\n  ...props\n}) => (\n  <Listbox.Option value={option} as={Fragment} disabled={option.isDisabled} {...props}>\n    {({ active }) => {\n      return (\n        <MenuItem\n          isSelected={isSelected}\n          isActive={active}\n          isDisabled={option.isDisabled}\n          hasEllipsis={menuItemsHaveEllipsis}\n        >\n          {option.content}\n        </MenuItem>\n      );\n    }}\n  </Listbox.Option>\n);\n\nconst SelectInfo = ({ label, hint }) => (\n  <>\n    {(label || hint) && (\n      <Box marginBottom=\"var(--grn-form-control-label-gap)\">\n        {label && <Listbox.Label as={FieldLabel}>{label}</Listbox.Label>}\n        {hint && <FieldHint>{hint}</FieldHint>}\n      </Box>\n    )}\n  </>\n);\n\nconst SelectMenu = ({ children, floating, hasPortal, isOpen, ...props }) => {\n  const Root = hasPortal ? FloatingPortal : Fragment;\n  return (\n    <Root>\n      <MenuCardTransition>\n        <Listbox.Options static ref={floating} as={MenuCard} isDisabled={!isOpen} {...props}>\n          {children}\n        </Listbox.Options>\n      </MenuCardTransition>\n    </Root>\n  );\n};\n\nconst getIsSelected = (isMultiple, option, selected) => {\n  if (!selected) return null;\n  if (isMultiple) {\n    return selected.some(selectedOption => selectedOption.content === option.content);\n  }\n\n  return option.value === selected.value;\n};\n\nexport const Select = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  trigger: customTrigger,\n  triggerVariant = 'box',\n  label,\n  hint,\n  menuZIndex,\n  menuItemsHaveEllipsis = true,\n  allowMultiple,\n  hasPortal = true,\n  placeholder,\n  isDisabled,\n  backgroundColor,\n  onClear,\n  size = 'm',\n}) => {\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n  const rootWidth = triggerVariant === 'text' ? 'fit-content' : undefined;\n\n  const optionMap = useMemo(() => {\n    return new Map(options.map(option => [option.value, option]));\n  }, [options]);\n\n  const selected = useMemo(() => {\n    const valueIsValid = value !== null && value !== undefined;\n\n    if (allowMultiple) {\n      return valueIsValid ? value.map(v => optionMap.get(v)) : [];\n    }\n\n    return valueIsValid ? optionMap.get(value) : null;\n  }, [allowMultiple, optionMap, value]);\n\n  const listboxValue = useMemo(() => {\n    const valueIsValid = selected !== undefined && selected !== null;\n\n    if (!valueIsValid) {\n      if (allowMultiple) return [];\n      else return null;\n    }\n\n    return selected;\n  }, [allowMultiple, selected]);\n\n  return (\n    <Listbox\n      as={Root}\n      value={listboxValue}\n      onChange={onChange}\n      width={rootWidth}\n      multiple={allowMultiple}\n      disabled={isDisabled}\n    >\n      {({ open }) => (\n        <>\n          <SelectInfo label={label} hint={hint} />\n\n          <Box position=\"relative\" ref={reference}>\n            <SelectButton\n              customTrigger={customTrigger}\n              variant={triggerVariant}\n              isMultiple={allowMultiple}\n              selected={selected}\n              placeholder={placeholder}\n              backgroundColor={backgroundColor}\n              onClear={onClear}\n              size={size}\n            />\n\n            <SelectMenu\n              placement={menuPlacement}\n              maxHeight={menuMaxHeight}\n              zIndex={menuZIndex}\n              floating={floating}\n              style={floatingStyles}\n              hasPortal={hasPortal}\n              isOpen={open}\n            >\n              {options.map((option, index) => {\n                const isSelected = getIsSelected(allowMultiple, option, selected);\n\n                if (option.type === 'divider') return <MenuItemDivider key={index} />;\n\n                return (\n                  <SelectMenuOption\n                    isSelected={isSelected}\n                    key={index}\n                    option={option}\n                    hasEllipsis={menuItemsHaveEllipsis}\n                    allowMultiple={allowMultiple}\n                  />\n                );\n              })}\n            </SelectMenu>\n          </Box>\n        </>\n      )}\n    </Listbox>\n  );\n};\n\nSelect.Label = FieldLabel;\nSelect.Hint = FieldHint;\nSelect.Trigger = Trigger;\n\nSelect.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.oneOfType([PropTypes.string, PropTypes.number, PropTypes.array]),\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuZIndex: types.zIndex,\n  menuMaxHeight: types.dimension,\n  trigger: PropTypes.func,\n  triggerVariant: PropTypes.oneOf(['box', 'text']),\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  allowMultiple: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  placeholder: PropTypes.string,\n  isDisabled: PropTypes.bool,\n  backgroundColor: types.color,\n  onClear: PropTypes.func,\n  size: PropTypes.oneOf(['m', 'l']),\n};\n"]} */",
|
|
136
141
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
137
142
|
});
|
|
138
|
-
const SelectMenuOption =
|
|
143
|
+
const SelectMenuOption = _ref8 => {
|
|
139
144
|
let {
|
|
140
145
|
option,
|
|
141
146
|
isSelected,
|
|
142
147
|
menuItemsHaveEllipsis,
|
|
143
148
|
allowMultiple
|
|
144
|
-
} =
|
|
145
|
-
props = _objectWithoutProperties(
|
|
149
|
+
} = _ref8,
|
|
150
|
+
props = _objectWithoutProperties(_ref8, _excluded2);
|
|
146
151
|
return ___EmotionJSX(Listbox.Option, _extends({
|
|
147
152
|
value: option,
|
|
148
153
|
as: Fragment,
|
|
149
154
|
disabled: option.isDisabled
|
|
150
|
-
}, props),
|
|
155
|
+
}, props), _ref9 => {
|
|
151
156
|
let {
|
|
152
157
|
active
|
|
153
|
-
} =
|
|
158
|
+
} = _ref9;
|
|
154
159
|
return ___EmotionJSX(MenuItem, {
|
|
155
160
|
isSelected: isSelected,
|
|
156
161
|
isActive: active,
|
|
@@ -159,25 +164,25 @@ const SelectMenuOption = _ref7 => {
|
|
|
159
164
|
}, option.content);
|
|
160
165
|
});
|
|
161
166
|
};
|
|
162
|
-
const SelectInfo =
|
|
167
|
+
const SelectInfo = _ref0 => {
|
|
163
168
|
let {
|
|
164
169
|
label,
|
|
165
170
|
hint
|
|
166
|
-
} =
|
|
171
|
+
} = _ref0;
|
|
167
172
|
return ___EmotionJSX(React.Fragment, null, (label || hint) && ___EmotionJSX(Box, {
|
|
168
173
|
marginBottom: "var(--grn-form-control-label-gap)"
|
|
169
174
|
}, label && ___EmotionJSX(Listbox.Label, {
|
|
170
175
|
as: FieldLabel
|
|
171
176
|
}, label), hint && ___EmotionJSX(FieldHint, null, hint)));
|
|
172
177
|
};
|
|
173
|
-
const SelectMenu =
|
|
178
|
+
const SelectMenu = _ref1 => {
|
|
174
179
|
let {
|
|
175
180
|
children,
|
|
176
181
|
floating,
|
|
177
182
|
hasPortal,
|
|
178
183
|
isOpen
|
|
179
|
-
} =
|
|
180
|
-
props = _objectWithoutProperties(
|
|
184
|
+
} = _ref1,
|
|
185
|
+
props = _objectWithoutProperties(_ref1, _excluded3);
|
|
181
186
|
const Root = hasPortal ? FloatingPortal : Fragment;
|
|
182
187
|
return ___EmotionJSX(Root, null, ___EmotionJSX(MenuCardTransition, null, ___EmotionJSX(Listbox.Options, _extends({
|
|
183
188
|
static: true,
|
|
@@ -193,7 +198,7 @@ const getIsSelected = (isMultiple, option, selected) => {
|
|
|
193
198
|
}
|
|
194
199
|
return option.value === selected.value;
|
|
195
200
|
};
|
|
196
|
-
export const Select =
|
|
201
|
+
export const Select = _ref10 => {
|
|
197
202
|
let {
|
|
198
203
|
options,
|
|
199
204
|
value,
|
|
@@ -214,7 +219,7 @@ export const Select = _ref1 => {
|
|
|
214
219
|
backgroundColor,
|
|
215
220
|
onClear,
|
|
216
221
|
size = 'm'
|
|
217
|
-
} =
|
|
222
|
+
} = _ref10;
|
|
218
223
|
const {
|
|
219
224
|
reference,
|
|
220
225
|
floating,
|
|
@@ -248,10 +253,10 @@ export const Select = _ref1 => {
|
|
|
248
253
|
width: rootWidth,
|
|
249
254
|
multiple: allowMultiple,
|
|
250
255
|
disabled: isDisabled
|
|
251
|
-
},
|
|
256
|
+
}, _ref11 => {
|
|
252
257
|
let {
|
|
253
258
|
open
|
|
254
|
-
} =
|
|
259
|
+
} = _ref11;
|
|
255
260
|
return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(SelectInfo, {
|
|
256
261
|
label: label,
|
|
257
262
|
hint: hint
|
|
@@ -29,13 +29,13 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
|
|
|
29
29
|
size
|
|
30
30
|
} = _ref3;
|
|
31
31
|
return "var(--grn-textbox-paddingX-".concat(size, ")");
|
|
32
|
-
}, ";display:flex;border-radius:var(--radius);padding:var(--inset);background:var(--grn-color-
|
|
32
|
+
}, ";display:flex;border-radius:var(--radius);padding:var(--inset);background:var(--grn-color-overlay);", p => !p.hasFullWidth && "width: fit-content", ";", p => p.hasFullWidth && "\n .TextToggle {\n flex: 1 0 0;\n }\n ", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNMEIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdGV4dC10b2dnbGUuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IgfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgc3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC0taW5zZXQ6IDJweDtcbiAgLS1oZWlnaHQ6ICR7KHsgc2l6ZSB9KSA9PiBgY2FsYyh2YXIoLS1ncm4tdGV4dGJveC1oZWlnaHQtJHtzaXplfSkgLSB2YXIoLS1pbnNldCkgKiAyKWB9O1xuICAtLXJhZGl1czogJHsoeyBzaXplIH0pID0+IGB2YXIoLS1ncm4tdGV4dGJveC1yYWRpdXMtJHtzaXplfSlgfTtcbiAgLS1wYWRkaW5nWDogJHsoeyBzaXplIH0pID0+IGB2YXIoLS1ncm4tdGV4dGJveC1wYWRkaW5nWC0ke3NpemV9KWB9O1xuXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGJvcmRlci1yYWRpdXM6IHZhcigtLXJhZGl1cyk7XG4gIHBhZGRpbmc6IHZhcigtLWluc2V0KTtcbiAgYmFja2dyb3VuZDogdmFyKC0tZ3JuLWNvbG9yLW92ZXJsYXkpO1xuXG4gICR7cCA9PiAhcC5oYXNGdWxsV2lkdGggJiYgYHdpZHRoOiBmaXQtY29udGVudGB9O1xuICAke3AgPT5cbiAgICBwLmhhc0Z1bGxXaWR0aCAmJlxuICAgIGBcbiAgICAuVGV4dFRvZ2dsZSB7XG4gICAgICBmbGV4OiAxIDAgMDtcbiAgICB9XG4gIGB9XG5gO1xuXG5jb25zdCBJdGVtV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7c3R5bGVzLmJ1dHRvblJlc2V0fTtcbiAgLS1ib3JkZXJDb2xvcjogdHJhbnNwYXJlbnQ7XG5cbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwIHZhcigtLXBhZGRpbmdYKTtcbiAgaGVpZ2h0OiB2YXIoLS1oZWlnaHQpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBjb2xvcjogdmFyKC0tZ3JuLWNvbG9yLWNvbnRlbnQyKTtcbiAgYm9yZGVyLXJhZGl1czogY2FsYyh2YXIoLS1yYWRpdXMpIC0gdmFyKC0taW5zZXQpKTtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tbGVhdmUpO1xuXG4gICY6aG92ZXIge1xuICAgIGNvbG9yOiB2YXIoLS1ncm4tY29sb3ItY29udGVudCk7XG4gICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24taG92ZXIpO1xuICB9XG5cbiAgJHtwID0+XG4gICAgcC5pc0FjdGl2ZSAmJlxuICAgIGBcbiAgICAtLWJvcmRlckNvbG9yOiAke2dldENvbG9yKCdzaGFkZTknKX07XG4gICAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50KTtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1hY3RpdmUpO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlMScpfTtcblxuICAgICY6aG92ZXIge1xuICAgICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tYWN0aXZlKTtcbiAgICB9XG4gIGB9XG5cbiAgJjpkaXNhYmxlZCB7XG4gICAgY29sb3I6ICR7Z2V0Q29sb3IoJ2Rpc2FibGVkQ29udGVudCcpfTtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFRleHRUb2dnbGUgPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRleHRUb2dnbGUoXG4gIHsgY2hpbGRyZW4sIGlzQWN0aXZlLCBpc0Rpc2FibGVkLCBvbkNsaWNrLCAuLi5wcm9wcyB9LFxuICByZWYsXG4pIHtcbiAgcmV0dXJuIChcbiAgICA8SXRlbVdyYXBwZXJcbiAgICAgIHJlZj17cmVmfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBpc0FjdGl2ZT17aXNBY3RpdmV9XG4gICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICBjbGFzc05hbWU9XCJUZXh0VG9nZ2xlXCJcbiAgICAgIHsuLi5wcm9wc31cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9JdGVtV3JhcHBlcj5cbiAgKTtcbn0pO1xuXG5leHBvcnQgY29uc3QgVGV4dFRvZ2dsZUdyb3VwID0gZm9yd2FyZFJlZihmdW5jdGlvbiBUZXh0VG9nZ2xlR3JvdXAoXG4gIHsgY2hpbGRyZW4sIGhhc0Z1bGxXaWR0aCwgc2l6ZSA9ICdtJywgLi4ucHJvcHMgfSxcbiAgcmVmLFxuKSB7XG4gIHJldHVybiAoXG4gICAgPFdyYXBwZXIgcmVmPXtyZWZ9IGhhc0Z1bGxXaWR0aD17aGFzRnVsbFdpZHRofSBzaXplPXtzaXplfSB7Li4ucHJvcHN9PlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvV3JhcHBlcj5cbiAgKTtcbn0pO1xuXG5UZXh0VG9nZ2xlR3JvdXAucHJvcFR5cGVzID0ge1xuICBjaGlsZHJlbjogUHJvcFR5cGVzLm5vZGUsXG4gIGhhc0Z1bGxXaWR0aDogUHJvcFR5cGVzLmJvb2wsXG59O1xuXG5UZXh0VG9nZ2xlLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBpc0FjdGl2ZTogUHJvcFR5cGVzLmJvb2wsXG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxuICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbn07XG4iXX0= */"));
|
|
33
33
|
const ItemWrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
|
|
34
34
|
target: "e1fb3cwm0"
|
|
35
35
|
} : {
|
|
36
36
|
target: "e1fb3cwm0",
|
|
37
37
|
label: "ItemWrapper"
|
|
38
|
-
})(styles.buttonReset, ";--borderColor:transparent;border:none;padding:0 var(--paddingX);height:var(--height);background-color:transparent;position:relative;color:var(--grn-color-content2);border-radius:calc(var(--radius) - var(--inset));white-space:nowrap;transition:var(--grn-transition-leave);&:hover{color:var(--grn-color-content);transition:var(--grn-transition-hover);}", p => p.isActive && "\n --borderColor: ".concat(getColor('shade9'), ";\n color: var(--grn-color-content);\n transition: var(--grn-transition-active);\n background-color: ").concat(getColor('shade1'), ";\n\n &:hover {\n transition: var(--grn-transition-active);\n }\n "), " &:disabled{color:", getColor('disabledContent'), ";pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
38
|
+
})(styles.buttonReset, ";--borderColor:transparent;border:none;padding:0 var(--paddingX);height:var(--height);background-color:transparent;position:relative;color:var(--grn-color-content2);border-radius:calc(var(--radius) - var(--inset));white-space:nowrap;transition:var(--grn-transition-leave);&:hover{color:var(--grn-color-content);transition:var(--grn-transition-hover);}", p => p.isActive && "\n --borderColor: ".concat(getColor('shade9'), ";\n color: var(--grn-color-content);\n transition: var(--grn-transition-active);\n background-color: ").concat(getColor('shade1'), ";\n\n &:hover {\n transition: var(--grn-transition-active);\n }\n "), " &:disabled{color:", getColor('disabledContent'), ";pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEyQmlDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldENvbG9yIH0gZnJvbSAnLi4vdXRpbGl0aWVzJztcbmltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IHN0eWxlcyB9IGZyb20gJy4uL2ZvdW5kYXRpb25hbCc7XG5cbmNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICAtLWluc2V0OiAycHg7XG4gIC0taGVpZ2h0OiAkeyh7IHNpemUgfSkgPT4gYGNhbGModmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LSR7c2l6ZX0pIC0gdmFyKC0taW5zZXQpICogMilgfTtcbiAgLS1yYWRpdXM6ICR7KHsgc2l6ZSB9KSA9PiBgdmFyKC0tZ3JuLXRleHRib3gtcmFkaXVzLSR7c2l6ZX0pYH07XG4gIC0tcGFkZGluZ1g6ICR7KHsgc2l6ZSB9KSA9PiBgdmFyKC0tZ3JuLXRleHRib3gtcGFkZGluZ1gtJHtzaXplfSlgfTtcblxuICBkaXNwbGF5OiBmbGV4O1xuICBib3JkZXItcmFkaXVzOiB2YXIoLS1yYWRpdXMpO1xuICBwYWRkaW5nOiB2YXIoLS1pbnNldCk7XG4gIGJhY2tncm91bmQ6IHZhcigtLWdybi1jb2xvci1vdmVybGF5KTtcblxuICAke3AgPT4gIXAuaGFzRnVsbFdpZHRoICYmIGB3aWR0aDogZml0LWNvbnRlbnRgfTtcbiAgJHtwID0+XG4gICAgcC5oYXNGdWxsV2lkdGggJiZcbiAgICBgXG4gICAgLlRleHRUb2dnbGUge1xuICAgICAgZmxleDogMSAwIDA7XG4gICAgfVxuICBgfVxuYDtcblxuY29uc3QgSXRlbVdyYXBwZXIgPSBzdHlsZWQuYnV0dG9uYFxuICAke3N0eWxlcy5idXR0b25SZXNldH07XG4gIC0tYm9yZGVyQ29sb3I6IHRyYW5zcGFyZW50O1xuXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMCB2YXIoLS1wYWRkaW5nWCk7XG4gIGhlaWdodDogdmFyKC0taGVpZ2h0KTtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50Mik7XG4gIGJvcmRlci1yYWRpdXM6IGNhbGModmFyKC0tcmFkaXVzKSAtIHZhcigtLWluc2V0KSk7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWxlYXZlKTtcblxuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWNvbG9yLWNvbnRlbnQpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWhvdmVyKTtcbiAgfVxuXG4gICR7cCA9PlxuICAgIHAuaXNBY3RpdmUgJiZcbiAgICBgXG4gICAgLS1ib3JkZXJDb2xvcjogJHtnZXRDb2xvcignc2hhZGU5Jyl9O1xuICAgIGNvbG9yOiB2YXIoLS1ncm4tY29sb3ItY29udGVudCk7XG4gICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tYWN0aXZlKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKCdzaGFkZTEnKX07XG5cbiAgICAmOmhvdmVyIHtcbiAgICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgfVxuICBgfVxuXG4gICY6ZGlzYWJsZWQge1xuICAgIGNvbG9yOiAke2dldENvbG9yKCdkaXNhYmxlZENvbnRlbnQnKX07XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUZXh0VG9nZ2xlID0gZm9yd2FyZFJlZihmdW5jdGlvbiBUZXh0VG9nZ2xlKFxuICB7IGNoaWxkcmVuLCBpc0FjdGl2ZSwgaXNEaXNhYmxlZCwgb25DbGljaywgLi4ucHJvcHMgfSxcbiAgcmVmLFxuKSB7XG4gIHJldHVybiAoXG4gICAgPEl0ZW1XcmFwcGVyXG4gICAgICByZWY9e3JlZn1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgaXNBY3RpdmU9e2lzQWN0aXZlfVxuICAgICAgZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgY2xhc3NOYW1lPVwiVGV4dFRvZ2dsZVwiXG4gICAgICB7Li4ucHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvSXRlbVdyYXBwZXI+XG4gICk7XG59KTtcblxuZXhwb3J0IGNvbnN0IFRleHRUb2dnbGVHcm91cCA9IGZvcndhcmRSZWYoZnVuY3Rpb24gVGV4dFRvZ2dsZUdyb3VwKFxuICB7IGNoaWxkcmVuLCBoYXNGdWxsV2lkdGgsIHNpemUgPSAnbScsIC4uLnByb3BzIH0sXG4gIHJlZixcbikge1xuICByZXR1cm4gKFxuICAgIDxXcmFwcGVyIHJlZj17cmVmfSBoYXNGdWxsV2lkdGg9e2hhc0Z1bGxXaWR0aH0gc2l6ZT17c2l6ZX0gey4uLnByb3BzfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1dyYXBwZXI+XG4gICk7XG59KTtcblxuVGV4dFRvZ2dsZUdyb3VwLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBoYXNGdWxsV2lkdGg6IFByb3BUeXBlcy5ib29sLFxufTtcblxuVGV4dFRvZ2dsZS5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaXNBY3RpdmU6IFByb3BUeXBlcy5ib29sLFxuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG59O1xuIl19 */"));
|
|
39
39
|
export const TextToggle = /*#__PURE__*/forwardRef(function TextToggle(_ref4, ref) {
|
|
40
40
|
let {
|
|
41
41
|
children,
|
|
@@ -3,7 +3,6 @@ const _excluded = ["value", "placeholder", "label", "id", "hasError", "errorMess
|
|
|
3
3
|
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
|
|
4
4
|
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
|
|
5
5
|
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
|
|
6
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
7
6
|
import React, { forwardRef } from 'react';
|
|
8
7
|
import PropTypes from 'prop-types';
|
|
9
8
|
import { FieldHint, FieldLabel, getFieldStyles } from '../foundational';
|
|
@@ -12,20 +11,6 @@ import { types } from '../types';
|
|
|
12
11
|
import { getColor, getRadius, getSpace, getTextSize } from '../utilities';
|
|
13
12
|
import { jsx as ___EmotionJSX } from "@emotion/react";
|
|
14
13
|
const counterBarHeight = '32px';
|
|
15
|
-
const CounterWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
16
|
-
target: "e1hvcshh2"
|
|
17
|
-
} : {
|
|
18
|
-
target: "e1hvcshh2",
|
|
19
|
-
label: "CounterWrapper"
|
|
20
|
-
})(process.env.NODE_ENV === "production" ? {
|
|
21
|
-
name: "d4ujbj",
|
|
22
|
-
styles: "position:absolute;bottom:var(--grn-border-size);left:var(--grn-border-size);right:var(--grn-border-size)"
|
|
23
|
-
} : {
|
|
24
|
-
name: "d4ujbj",
|
|
25
|
-
styles: "position:absolute;bottom:var(--grn-border-size);left:var(--grn-border-size);right:var(--grn-border-size)",
|
|
26
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHRhcmVhLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVaUMiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdGV4dGFyZWEuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgRmllbGRIaW50LCBGaWVsZExhYmVsLCBnZXRGaWVsZFN0eWxlcyB9IGZyb20gJy4uL2ZvdW5kYXRpb25hbCc7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuL2JveCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGdldENvbG9yLCBnZXRSYWRpdXMsIGdldFNwYWNlLCBnZXRUZXh0U2l6ZSB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmNvbnN0IGNvdW50ZXJCYXJIZWlnaHQgPSAnMzJweCc7XG5cbmNvbnN0IENvdW50ZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IHZhcigtLWdybi1ib3JkZXItc2l6ZSk7XG4gIGxlZnQ6IHZhcigtLWdybi1ib3JkZXItc2l6ZSk7XG4gIHJpZ2h0OiB2YXIoLS1ncm4tYm9yZGVyLXNpemUpO1xuYDtcblxuY29uc3QgQ291bnRlclJvb3QgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBncmlkO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGVuZDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ3JpZC1hdXRvLWZsb3c6IGNvbHVtbjtcbiAgcGFkZGluZy1pbmxpbmU6ICR7Z2V0U3BhY2UoJ3MyJyl9O1xuICBoZWlnaHQ6ICR7Y291bnRlckJhckhlaWdodH07XG4gIGJhY2tncm91bmQ6ICR7KHsgYmFja2dyb3VuZENvbG9yIH0pID0+IGdldENvbG9yKGJhY2tncm91bmRDb2xvcil9O1xuICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiBjYWxjKCR7Z2V0UmFkaXVzKCdzJyl9IC0gdmFyKC0tZ3JuLWJvcmRlci1zaXplKSk7XG4gIGJvcmRlci1ib3R0b20tcmlnaHQtcmFkaXVzOiBjYWxjKCR7Z2V0UmFkaXVzKCdzJyl9IC0gdmFyKC0tZ3JuLWJvcmRlci1zaXplKSk7XG4gIGZvbnQtc2l6ZTogJHtnZXRUZXh0U2l6ZSgncycpfTtcbmA7XG5cbmNvbnN0IENvdW50ZXIgPSAoeyBsZW5ndGgsIG1heExlbmd0aCwgYmFja2dyb3VuZENvbG9yID0gJ3ZhcigtLWdybi1maWVsZC1iYWNrZ3JvdW5kKScgfSkgPT4ge1xuICByZXR1cm4gKFxuICAgIDxDb3VudGVyUm9vdFxuICAgICAgcGFkZGluZ1g9XCJzXCJcbiAgICAgIHBhZGRpbmdZPVwieHNcIlxuICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICB3aWR0aD1cIjEwMCVcIlxuICAgICAganVzdGlmeUNvbnRlbnQ9XCJlbmRcIlxuICAgID5cbiAgICAgIHtsZW5ndGh9XG4gICAgICA8Qm94IGNvbG9yPVwiY29udGVudDJcIj4mbmJzcDsvIHttYXhMZW5ndGh9PC9Cb3g+XG4gICAgPC9Db3VudGVyUm9vdD5cbiAgKTtcbn07XG5cbmNvbnN0IFRleHRhcmVhV3JhcHBlciA9ICh7IGNoaWxkcmVuLCBtYXhMZW5ndGggfSkgPT4ge1xuICBpZiAoIW1heExlbmd0aCkgcmV0dXJuIGNoaWxkcmVuO1xuXG4gIHJldHVybiA8Qm94IHBvc2l0aW9uPVwicmVsYXRpdmVcIj57Y2hpbGRyZW59PC9Cb3g+O1xufTtcblxuY29uc3QgVGV4dGFyZWFGaWVsZCA9IHN0eWxlZC50ZXh0YXJlYWBcbiAgLypcbiAgICB2aXN1YWxseSBtYXRjaCB4IGFuZCB5IHBhZGRpbmcuXG4gICAgYXBwbHkgeCBwYWRkaW5nIHRvIHksIG1pbnVzIHRleHQncyB1cHBlciBzcGFjZSBnZW5lcmF0ZWQgYnkgbGluZSBoZWlnaHQuXG4gICovXG4gIC0tcGFkZGluZ1g6ICR7KHsgc2l6ZSB9KSA9PiBgdmFyKC0tZ3JuLWZpZWxkLXBhZGRpbmdYLSR7c2l6ZX0pYH07XG5cbiAgLS10ZXh0LWV4dHJhLXRvcC1zcGFjZTogY2FsYygodmFyKC0tZ3JuLWxpbmVIZWlnaHQtZ2xvYmFsKSAtIHZhcigtLWdybi1jYXApKSAvIDIpO1xuICAtLXBhZGRpbmctYmxvY2s6IGNhbGModmFyKC0tcGFkZGluZ1gpIC0gdmFyKC0tdGV4dC1leHRyYS10b3Atc3BhY2UpKTtcblxuICAkeyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IsIHNpemUgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yLCBzaXplIH0pfTtcbiAgcmVzaXplOiBub25lO1xuICBwYWRkaW5nLWlubGluZTogdmFyKC0tcGFkZGluZ1gpO1xuICBwYWRkaW5nLWJsb2NrOiByb3VuZCh1cCwgdmFyKC0tcGFkZGluZy1ibG9jayksIDFweCk7XG5cbiAgLypcbiAgICB1c2luZyBib3JkZXIgdG8gY3JlYXRlIGJvdHRvbSBzcGFjZSxcbiAgICBzcGVjaWZpY2FsbHkgYm9yZGVyIG1ldGhvZCwgdG8gbWFrZSBzdXJlIHRoZSBzY3JvbGwgYmVoYXZlcyBjb3JyZWN0bHlcbiAgKi9cbiAgJHsoeyBoYXNDb3VudGVyIH0pID0+IGhhc0NvdW50ZXIgJiYgYGJvcmRlci1ib3R0b20td2lkdGg6ICR7Y291bnRlckJhckhlaWdodH1gfVxuYDtcblxuZXhwb3J0IGNvbnN0IFRleHRhcmVhID0gZm9yd2FyZFJlZihmdW5jdGlvbiBUZXh0YXJlYShcbiAge1xuICAgIHZhbHVlLFxuICAgIHBsYWNlaG9sZGVyLFxuICAgIGxhYmVsLFxuICAgIGlkLFxuICAgIGhhc0Vycm9yLFxuICAgIGVycm9yTWVzc2FnZSxcbiAgICBpc1JlYWRPbmx5LFxuICAgIGlzRGlzYWJsZWQsXG4gICAgaGludCxcbiAgICBtYXhMZW5ndGgsXG4gICAgY2hpbGRyZW4sXG4gICAgcm93cyA9IDMsXG4gICAgYmFja2dyb3VuZENvbG9yLFxuICAgIHNpemUgPSAnbScsXG4gICAgLi4ucHJvcHNcbiAgfSxcbiAgcmVmLFxuKSB7XG4gIGNvbnN0IGhhc0NvdW50ZXIgPSBCb29sZWFuKG1heExlbmd0aCk7XG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIHsobGFiZWwgfHwgaGludCkgJiYgKFxuICAgICAgICA8Qm94IG1hcmdpbkJvdHRvbT1cInZhcigtLWdybi1mb3JtLWNvbnRyb2wtbGFiZWwtZ2FwKVwiPlxuICAgICAgICAgIHtsYWJlbCAmJiA8RmllbGRMYWJlbCBodG1sRm9yPXtpZH0+e2xhYmVsfTwvRmllbGRMYWJlbD59XG4gICAgICAgICAge2hpbnQgJiYgPEZpZWxkSGludD57aGludH08L0ZpZWxkSGludD59XG4gICAgICAgIDwvQm94PlxuICAgICAgKX1cblxuICAgICAgPFRleHRhcmVhV3JhcHBlciBtYXhMZW5ndGg9e21heExlbmd0aH0+XG4gICAgICAgIDxUZXh0YXJlYUZpZWxkXG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgaWQ9e2lkfVxuICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICBuYW1lPXtpZH1cbiAgICAgICAgICByb3dzPXtyb3dzfVxuICAgICAgICAgIG1heExlbmd0aD17bWF4TGVuZ3RofVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgICAgICByZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICAgICAgaGFzQ291bnRlcj17aGFzQ291bnRlcn1cbiAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgLz5cbiAgICAgICAge2hhc0NvdW50ZXIgJiYgKFxuICAgICAgICAgIDxDb3VudGVyV3JhcHBlcj5cbiAgICAgICAgICAgIDxDb3VudGVyXG4gICAgICAgICAgICAgIGxlbmd0aD17dmFsdWUubGVuZ3RofVxuICAgICAgICAgICAgICBtYXhMZW5ndGg9e21heExlbmd0aH1cbiAgICAgICAgICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgIDwvQ291bnRlcldyYXBwZXI+XG4gICAgICAgICl9XG4gICAgICA8L1RleHRhcmVhV3JhcHBlcj5cblxuICAgICAge2Vycm9yTWVzc2FnZSAmJiAoXG4gICAgICAgIDxCb3ggY29sb3I9XCJjb250ZW50RGFuZ2VyXCIgbWFyZ2luVG9wPVwidmFyKC0tZ3JuLWZvcm0tY29udHJvbC1sYWJlbC1nYXApXCI+XG4gICAgICAgICAge2Vycm9yTWVzc2FnZX1cbiAgICAgICAgPC9Cb3g+XG4gICAgICApfVxuICAgIDwvZGl2PlxuICApO1xufSk7XG5cblRleHRhcmVhLkNvdW50ZXIgPSBDb3VudGVyO1xuXG5UZXh0YXJlYS5wcm9wVHlwZXMgPSB7XG4gIHZhbHVlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBwbGFjZWhvbGRlcjogUHJvcFR5cGVzLnN0cmluZyxcbiAgbGFiZWw6IHR5cGVzLmxhYmVsLFxuICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICBoYXNFcnJvcjogUHJvcFR5cGVzLmJvb2wsXG4gIGVycm9yTWVzc2FnZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgaXNSZWFkT25seTogUHJvcFR5cGVzLmJvb2wsXG4gIGlzRGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICBoaW50OiB0eXBlcy5oaW50LFxuICBtYXhMZW5ndGg6IFByb3BUeXBlcy5udW1iZXIsXG4gIHJvd3M6IFByb3BUeXBlcy5udW1iZXIsXG4gIGJhY2tncm91bmRDb2xvcjogdHlwZXMuY29sb3IsXG59O1xuIl19 */",
|
|
27
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
28
|
-
});
|
|
29
14
|
const CounterRoot = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
30
15
|
target: "e1hvcshh1"
|
|
31
16
|
} : {
|
|
@@ -36,7 +21,7 @@ const CounterRoot = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
|
|
|
36
21
|
backgroundColor
|
|
37
22
|
} = _ref;
|
|
38
23
|
return getColor(backgroundColor);
|
|
39
|
-
}, ";border-bottom-left-radius:calc(", getRadius('s'), " - var(--grn-border-size));border-bottom-right-radius:calc(", getRadius('s'), " - var(--grn-border-size));font-size:", getTextSize('s'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
24
|
+
}, ";border-bottom-left-radius:calc(", getRadius('s'), " - var(--grn-border-size));border-bottom-right-radius:calc(", getRadius('s'), " - var(--grn-border-size));font-size:", getTextSize('s'), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHRhcmVhLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVOEIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdGV4dGFyZWEuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgRmllbGRIaW50LCBGaWVsZExhYmVsLCBnZXRGaWVsZFN0eWxlcyB9IGZyb20gJy4uL2ZvdW5kYXRpb25hbCc7XG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuL2JveCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGdldENvbG9yLCBnZXRSYWRpdXMsIGdldFNwYWNlLCBnZXRUZXh0U2l6ZSB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmNvbnN0IGNvdW50ZXJCYXJIZWlnaHQgPSAnMzJweCc7XG5cbmNvbnN0IENvdW50ZXJSb290ID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZ3JpZDtcbiAganVzdGlmeS1jb250ZW50OiBlbmQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdyaWQtYXV0by1mbG93OiBjb2x1bW47XG4gIHBhZGRpbmctaW5saW5lOiAke2dldFNwYWNlKCdzMicpfTtcbiAgaGVpZ2h0OiAke2NvdW50ZXJCYXJIZWlnaHR9O1xuICBiYWNrZ3JvdW5kOiAkeyh7IGJhY2tncm91bmRDb2xvciB9KSA9PiBnZXRDb2xvcihiYWNrZ3JvdW5kQ29sb3IpfTtcbiAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogY2FsYygke2dldFJhZGl1cygncycpfSAtIHZhcigtLWdybi1ib3JkZXItc2l6ZSkpO1xuICBib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogY2FsYygke2dldFJhZGl1cygncycpfSAtIHZhcigtLWdybi1ib3JkZXItc2l6ZSkpO1xuICBmb250LXNpemU6ICR7Z2V0VGV4dFNpemUoJ3MnKX07XG5gO1xuXG5jb25zdCBDb3VudGVyID0gKHsgbGVuZ3RoLCBtYXhMZW5ndGgsIGJhY2tncm91bmRDb2xvciA9ICd2YXIoLS1ncm4tZmllbGQtYmFja2dyb3VuZCknIH0pID0+IHtcbiAgcmV0dXJuIChcbiAgICA8Q291bnRlclJvb3RcbiAgICAgIHBhZGRpbmdYPVwic1wiXG4gICAgICBwYWRkaW5nWT1cInhzXCJcbiAgICAgIGJhY2tncm91bmRDb2xvcj17YmFja2dyb3VuZENvbG9yfVxuICAgICAgd2lkdGg9XCIxMDAlXCJcbiAgICAgIGp1c3RpZnlDb250ZW50PVwiZW5kXCJcbiAgICA+XG4gICAgICB7bGVuZ3RofVxuICAgICAgPEJveCBjb2xvcj1cImNvbnRlbnQyXCI+Jm5ic3A7LyB7bWF4TGVuZ3RofTwvQm94PlxuICAgIDwvQ291bnRlclJvb3Q+XG4gICk7XG59O1xuXG5jb25zdCBUZXh0YXJlYVdyYXBwZXIgPSAoeyBjaGlsZHJlbiwgbWF4TGVuZ3RoIH0pID0+IHtcbiAgaWYgKCFtYXhMZW5ndGgpIHJldHVybiBjaGlsZHJlbjtcblxuICByZXR1cm4gPEJveCBwb3NpdGlvbj1cInJlbGF0aXZlXCI+e2NoaWxkcmVufTwvQm94Pjtcbn07XG5cbmNvbnN0IFRleHRhcmVhRmllbGQgPSBzdHlsZWQudGV4dGFyZWFgXG4gIC8qXG4gICAgdmlzdWFsbHkgbWF0Y2ggeCBhbmQgeSBwYWRkaW5nLlxuICAgIGFwcGx5IHggcGFkZGluZyB0byB5LCBtaW51cyB0ZXh0J3MgdXBwZXIgc3BhY2UgZ2VuZXJhdGVkIGJ5IGxpbmUgaGVpZ2h0LlxuICAqL1xuICAtLXBhZGRpbmdYOiAkeyh7IHNpemUgfSkgPT4gYHZhcigtLWdybi1maWVsZC1wYWRkaW5nWC0ke3NpemV9KWB9O1xuXG4gIC0tdGV4dC1leHRyYS10b3Atc3BhY2U6IGNhbGMoKHZhcigtLWdybi1saW5lSGVpZ2h0LWdsb2JhbCkgLSB2YXIoLS1ncm4tY2FwKSkgLyAyKTtcbiAgLS1wYWRkaW5nLWJsb2NrOiBjYWxjKHZhcigtLXBhZGRpbmdYKSAtIHZhcigtLXRleHQtZXh0cmEtdG9wLXNwYWNlKSk7XG5cbiAgJHsoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yLCBzaXplIH0pID0+IGdldEZpZWxkU3R5bGVzKHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciwgc2l6ZSB9KX07XG4gIHJlc2l6ZTogbm9uZTtcbiAgcGFkZGluZy1pbmxpbmU6IHZhcigtLXBhZGRpbmdYKTtcbiAgcGFkZGluZy1ibG9jazogcm91bmQodXAsIHZhcigtLXBhZGRpbmctYmxvY2spLCAxcHgpO1xuXG4gICR7KHsgaGFzQ291bnRlciB9KSA9PlxuICAgIGhhc0NvdW50ZXIgJiZcbiAgICBgXG4gICAgYm9yZGVyLWJvdHRvbS1sZWZ0LXJhZGl1czogMHB4O1xuICAgIGJvcmRlci1ib3R0b20tcmlnaHQtcmFkaXVzOiAwcHg7XG4gIGB9XG5gO1xuXG5leHBvcnQgY29uc3QgVGV4dGFyZWEgPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRleHRhcmVhKFxuICB7XG4gICAgdmFsdWUsXG4gICAgcGxhY2Vob2xkZXIsXG4gICAgbGFiZWwsXG4gICAgaWQsXG4gICAgaGFzRXJyb3IsXG4gICAgZXJyb3JNZXNzYWdlLFxuICAgIGlzUmVhZE9ubHksXG4gICAgaXNEaXNhYmxlZCxcbiAgICBoaW50LFxuICAgIG1heExlbmd0aCxcbiAgICBjaGlsZHJlbixcbiAgICByb3dzID0gMyxcbiAgICBiYWNrZ3JvdW5kQ29sb3IsXG4gICAgc2l6ZSA9ICdtJyxcbiAgICAuLi5wcm9wc1xuICB9LFxuICByZWYsXG4pIHtcbiAgY29uc3QgaGFzQ291bnRlciA9IEJvb2xlYW4obWF4TGVuZ3RoKTtcbiAgcmV0dXJuIChcbiAgICA8ZGl2PlxuICAgICAgeyhsYWJlbCB8fCBoaW50KSAmJiAoXG4gICAgICAgIDxCb3ggbWFyZ2luQm90dG9tPVwidmFyKC0tZ3JuLWZvcm0tY29udHJvbC1sYWJlbC1nYXApXCI+XG4gICAgICAgICAge2xhYmVsICYmIDxGaWVsZExhYmVsIGh0bWxGb3I9e2lkfT57bGFiZWx9PC9GaWVsZExhYmVsPn1cbiAgICAgICAgICB7aGludCAmJiA8RmllbGRIaW50PntoaW50fTwvRmllbGRIaW50Pn1cbiAgICAgICAgPC9Cb3g+XG4gICAgICApfVxuXG4gICAgICA8VGV4dGFyZWFXcmFwcGVyIG1heExlbmd0aD17bWF4TGVuZ3RofT5cbiAgICAgICAgPFRleHRhcmVhRmllbGRcbiAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgdmFsdWU9e3ZhbHVlfVxuICAgICAgICAgIG5hbWU9e2lkfVxuICAgICAgICAgIHJvd3M9e3Jvd3N9XG4gICAgICAgICAgbWF4TGVuZ3RoPXttYXhMZW5ndGh9XG4gICAgICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgICAgIHJlYWRPbmx5PXtpc1JlYWRPbmx5fVxuICAgICAgICAgIGRpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgICAgICBoYXNDb3VudGVyPXtoYXNDb3VudGVyfVxuICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAvPlxuICAgICAgICB7aGFzQ291bnRlciAmJiAoXG4gICAgICAgICAgPENvdW50ZXIgbGVuZ3RoPXt2YWx1ZS5sZW5ndGh9IG1heExlbmd0aD17bWF4TGVuZ3RofSBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn0gLz5cbiAgICAgICAgKX1cbiAgICAgIDwvVGV4dGFyZWFXcmFwcGVyPlxuXG4gICAgICB7ZXJyb3JNZXNzYWdlICYmIChcbiAgICAgICAgPEJveCBjb2xvcj1cImNvbnRlbnREYW5nZXJcIiBtYXJnaW5Ub3A9XCJ2YXIoLS1ncm4tZm9ybS1jb250cm9sLWxhYmVsLWdhcClcIj5cbiAgICAgICAgICB7ZXJyb3JNZXNzYWdlfVxuICAgICAgICA8L0JveD5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuVGV4dGFyZWEuQ291bnRlciA9IENvdW50ZXI7XG5cblRleHRhcmVhLnByb3BUeXBlcyA9IHtcbiAgdmFsdWU6IFByb3BUeXBlcy5zdHJpbmcsXG4gIHBsYWNlaG9sZGVyOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBsYWJlbDogdHlwZXMubGFiZWwsXG4gIGlkOiBQcm9wVHlwZXMuc3RyaW5nLmlzUmVxdWlyZWQsXG4gIGhhc0Vycm9yOiBQcm9wVHlwZXMuYm9vbCxcbiAgZXJyb3JNZXNzYWdlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBpc1JlYWRPbmx5OiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGhpbnQ6IHR5cGVzLmhpbnQsXG4gIG1heExlbmd0aDogUHJvcFR5cGVzLm51bWJlcixcbiAgcm93czogUHJvcFR5cGVzLm51bWJlcixcbiAgYmFja2dyb3VuZENvbG9yOiB0eXBlcy5jb2xvcixcbn07XG4iXX0= */"));
|
|
40
25
|
const Counter = _ref2 => {
|
|
41
26
|
let {
|
|
42
27
|
length,
|
|
@@ -88,8 +73,8 @@ const TextareaField = /*#__PURE__*/_styled("textarea", process.env.NODE_ENV ===
|
|
|
88
73
|
let {
|
|
89
74
|
hasCounter
|
|
90
75
|
} = _ref6;
|
|
91
|
-
return hasCounter && "border-bottom-
|
|
92
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
76
|
+
return hasCounter && "\n border-bottom-left-radius: 0px;\n border-bottom-right-radius: 0px;\n ";
|
|
77
|
+
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHRhcmVhLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE0Q3FDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL3RleHRhcmVhLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcbmltcG9ydCB7IEZpZWxkSGludCwgRmllbGRMYWJlbCwgZ2V0RmllbGRTdHlsZXMgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuaW1wb3J0IHsgQm94IH0gZnJvbSAnLi9ib3gnO1xuaW1wb3J0IHsgdHlwZXMgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBnZXRDb2xvciwgZ2V0UmFkaXVzLCBnZXRTcGFjZSwgZ2V0VGV4dFNpemUgfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5jb25zdCBjb3VudGVyQmFySGVpZ2h0ID0gJzMycHgnO1xuXG5jb25zdCBDb3VudGVyUm9vdCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGdyaWQ7XG4gIGp1c3RpZnktY29udGVudDogZW5kO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBncmlkLWF1dG8tZmxvdzogY29sdW1uO1xuICBwYWRkaW5nLWlubGluZTogJHtnZXRTcGFjZSgnczInKX07XG4gIGhlaWdodDogJHtjb3VudGVyQmFySGVpZ2h0fTtcbiAgYmFja2dyb3VuZDogJHsoeyBiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gZ2V0Q29sb3IoYmFja2dyb3VuZENvbG9yKX07XG4gIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IGNhbGMoJHtnZXRSYWRpdXMoJ3MnKX0gLSB2YXIoLS1ncm4tYm9yZGVyLXNpemUpKTtcbiAgYm9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6IGNhbGMoJHtnZXRSYWRpdXMoJ3MnKX0gLSB2YXIoLS1ncm4tYm9yZGVyLXNpemUpKTtcbiAgZm9udC1zaXplOiAke2dldFRleHRTaXplKCdzJyl9O1xuYDtcblxuY29uc3QgQ291bnRlciA9ICh7IGxlbmd0aCwgbWF4TGVuZ3RoLCBiYWNrZ3JvdW5kQ29sb3IgPSAndmFyKC0tZ3JuLWZpZWxkLWJhY2tncm91bmQpJyB9KSA9PiB7XG4gIHJldHVybiAoXG4gICAgPENvdW50ZXJSb290XG4gICAgICBwYWRkaW5nWD1cInNcIlxuICAgICAgcGFkZGluZ1k9XCJ4c1wiXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgIHdpZHRoPVwiMTAwJVwiXG4gICAgICBqdXN0aWZ5Q29udGVudD1cImVuZFwiXG4gICAgPlxuICAgICAge2xlbmd0aH1cbiAgICAgIDxCb3ggY29sb3I9XCJjb250ZW50MlwiPiZuYnNwOy8ge21heExlbmd0aH08L0JveD5cbiAgICA8L0NvdW50ZXJSb290PlxuICApO1xufTtcblxuY29uc3QgVGV4dGFyZWFXcmFwcGVyID0gKHsgY2hpbGRyZW4sIG1heExlbmd0aCB9KSA9PiB7XG4gIGlmICghbWF4TGVuZ3RoKSByZXR1cm4gY2hpbGRyZW47XG5cbiAgcmV0dXJuIDxCb3ggcG9zaXRpb249XCJyZWxhdGl2ZVwiPntjaGlsZHJlbn08L0JveD47XG59O1xuXG5jb25zdCBUZXh0YXJlYUZpZWxkID0gc3R5bGVkLnRleHRhcmVhYFxuICAvKlxuICAgIHZpc3VhbGx5IG1hdGNoIHggYW5kIHkgcGFkZGluZy5cbiAgICBhcHBseSB4IHBhZGRpbmcgdG8geSwgbWludXMgdGV4dCdzIHVwcGVyIHNwYWNlIGdlbmVyYXRlZCBieSBsaW5lIGhlaWdodC5cbiAgKi9cbiAgLS1wYWRkaW5nWDogJHsoeyBzaXplIH0pID0+IGB2YXIoLS1ncm4tZmllbGQtcGFkZGluZ1gtJHtzaXplfSlgfTtcblxuICAtLXRleHQtZXh0cmEtdG9wLXNwYWNlOiBjYWxjKCh2YXIoLS1ncm4tbGluZUhlaWdodC1nbG9iYWwpIC0gdmFyKC0tZ3JuLWNhcCkpIC8gMik7XG4gIC0tcGFkZGluZy1ibG9jazogY2FsYyh2YXIoLS1wYWRkaW5nWCkgLSB2YXIoLS10ZXh0LWV4dHJhLXRvcC1zcGFjZSkpO1xuXG4gICR7KHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciwgc2l6ZSB9KSA9PiBnZXRGaWVsZFN0eWxlcyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IsIHNpemUgfSl9O1xuICByZXNpemU6IG5vbmU7XG4gIHBhZGRpbmctaW5saW5lOiB2YXIoLS1wYWRkaW5nWCk7XG4gIHBhZGRpbmctYmxvY2s6IHJvdW5kKHVwLCB2YXIoLS1wYWRkaW5nLWJsb2NrKSwgMXB4KTtcblxuICAkeyh7IGhhc0NvdW50ZXIgfSkgPT5cbiAgICBoYXNDb3VudGVyICYmXG4gICAgYFxuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDBweDtcbiAgICBib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMHB4O1xuICBgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFRleHRhcmVhID0gZm9yd2FyZFJlZihmdW5jdGlvbiBUZXh0YXJlYShcbiAge1xuICAgIHZhbHVlLFxuICAgIHBsYWNlaG9sZGVyLFxuICAgIGxhYmVsLFxuICAgIGlkLFxuICAgIGhhc0Vycm9yLFxuICAgIGVycm9yTWVzc2FnZSxcbiAgICBpc1JlYWRPbmx5LFxuICAgIGlzRGlzYWJsZWQsXG4gICAgaGludCxcbiAgICBtYXhMZW5ndGgsXG4gICAgY2hpbGRyZW4sXG4gICAgcm93cyA9IDMsXG4gICAgYmFja2dyb3VuZENvbG9yLFxuICAgIHNpemUgPSAnbScsXG4gICAgLi4ucHJvcHNcbiAgfSxcbiAgcmVmLFxuKSB7XG4gIGNvbnN0IGhhc0NvdW50ZXIgPSBCb29sZWFuKG1heExlbmd0aCk7XG4gIHJldHVybiAoXG4gICAgPGRpdj5cbiAgICAgIHsobGFiZWwgfHwgaGludCkgJiYgKFxuICAgICAgICA8Qm94IG1hcmdpbkJvdHRvbT1cInZhcigtLWdybi1mb3JtLWNvbnRyb2wtbGFiZWwtZ2FwKVwiPlxuICAgICAgICAgIHtsYWJlbCAmJiA8RmllbGRMYWJlbCBodG1sRm9yPXtpZH0+e2xhYmVsfTwvRmllbGRMYWJlbD59XG4gICAgICAgICAge2hpbnQgJiYgPEZpZWxkSGludD57aGludH08L0ZpZWxkSGludD59XG4gICAgICAgIDwvQm94PlxuICAgICAgKX1cblxuICAgICAgPFRleHRhcmVhV3JhcHBlciBtYXhMZW5ndGg9e21heExlbmd0aH0+XG4gICAgICAgIDxUZXh0YXJlYUZpZWxkXG4gICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgaWQ9e2lkfVxuICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICBuYW1lPXtpZH1cbiAgICAgICAgICByb3dzPXtyb3dzfVxuICAgICAgICAgIG1heExlbmd0aD17bWF4TGVuZ3RofVxuICAgICAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgICAgICByZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICAgICAgaGFzQ291bnRlcj17aGFzQ291bnRlcn1cbiAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgLz5cbiAgICAgICAge2hhc0NvdW50ZXIgJiYgKFxuICAgICAgICAgIDxDb3VudGVyIGxlbmd0aD17dmFsdWUubGVuZ3RofSBtYXhMZW5ndGg9e21heExlbmd0aH0gYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9IC8+XG4gICAgICAgICl9XG4gICAgICA8L1RleHRhcmVhV3JhcHBlcj5cblxuICAgICAge2Vycm9yTWVzc2FnZSAmJiAoXG4gICAgICAgIDxCb3ggY29sb3I9XCJjb250ZW50RGFuZ2VyXCIgbWFyZ2luVG9wPVwidmFyKC0tZ3JuLWZvcm0tY29udHJvbC1sYWJlbC1nYXApXCI+XG4gICAgICAgICAge2Vycm9yTWVzc2FnZX1cbiAgICAgICAgPC9Cb3g+XG4gICAgICApfVxuICAgIDwvZGl2PlxuICApO1xufSk7XG5cblRleHRhcmVhLkNvdW50ZXIgPSBDb3VudGVyO1xuXG5UZXh0YXJlYS5wcm9wVHlwZXMgPSB7XG4gIHZhbHVlOiBQcm9wVHlwZXMuc3RyaW5nLFxuICBwbGFjZWhvbGRlcjogUHJvcFR5cGVzLnN0cmluZyxcbiAgbGFiZWw6IHR5cGVzLmxhYmVsLFxuICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICBoYXNFcnJvcjogUHJvcFR5cGVzLmJvb2wsXG4gIGVycm9yTWVzc2FnZTogUHJvcFR5cGVzLnN0cmluZyxcbiAgaXNSZWFkT25seTogUHJvcFR5cGVzLmJvb2wsXG4gIGlzRGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICBoaW50OiB0eXBlcy5oaW50LFxuICBtYXhMZW5ndGg6IFByb3BUeXBlcy5udW1iZXIsXG4gIHJvd3M6IFByb3BUeXBlcy5udW1iZXIsXG4gIGJhY2tncm91bmRDb2xvcjogdHlwZXMuY29sb3IsXG59O1xuIl19 */"));
|
|
93
78
|
export const Textarea = /*#__PURE__*/forwardRef(function Textarea(_ref7, ref) {
|
|
94
79
|
let {
|
|
95
80
|
value,
|
|
@@ -129,11 +114,11 @@ export const Textarea = /*#__PURE__*/forwardRef(function Textarea(_ref7, ref) {
|
|
|
129
114
|
backgroundColor: backgroundColor,
|
|
130
115
|
hasCounter: hasCounter,
|
|
131
116
|
size: size
|
|
132
|
-
}, props)), hasCounter && ___EmotionJSX(
|
|
117
|
+
}, props)), hasCounter && ___EmotionJSX(Counter, {
|
|
133
118
|
length: value.length,
|
|
134
119
|
maxLength: maxLength,
|
|
135
120
|
backgroundColor: backgroundColor
|
|
136
|
-
}))
|
|
121
|
+
})), errorMessage && ___EmotionJSX(Box, {
|
|
137
122
|
color: "contentDanger",
|
|
138
123
|
marginTop: "var(--grn-form-control-label-gap)"
|
|
139
124
|
}, errorMessage));
|
package/es/styles/colors/core.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
const core = "\n :root {\n --sh-h: 60;\n --sh-s: 12%;\n --bf-l: 20%;\n --wf-l: calc(100% - var(--bf-l));\n }\n\n :root {\n --grn-color-red: var(--grn-color-red6);\n --grn-color-yellow: var(--grn-color-yellow5);\n --grn-color-green: var(--grn-color-green6);\n --grn-color-blue: var(--grn-color-blue6);\n }\n\n :root {\n --grn-color-red1: hsl(12 100% 97%);\n --grn-color-red2: hsl(12 100% 91%);\n --grn-color-red3: hsl(12 100% 82%);\n --grn-color-red4: hsl(12 99% 72%);\n --grn-color-red5: hsl(12 99% 63%);\n --grn-color-red6: hsl(13 97% 51%);\n --grn-color-red7: hsl(13 97% 42%);\n --grn-color-red8: hsl(7 98% 35%);\n --grn-color-red9: hsl(7 98% 28%);\n --grn-color-red10: hsl(5 99% 21%);\n --grn-color-red11: hsl(1 100% 15%);\n --grn-color-red12: hsl(357 100% 8%);\n\n --grn-color-yellow1: hsl(46 100% 95%);\n --grn-color-yellow2: hsl(47 97% 85%);\n --grn-color-yellow3: hsl(49 93% 73%);\n --grn-color-yellow4: hsl(51 89% 62%);\n --grn-color-yellow5: hsl(53 84% 48%);\n --grn-color-yellow6: hsl(53 77% 43%);\n --grn-color-yellow7: hsl(52 68% 37%);\n --grn-color-yellow8: hsl(52 58% 35%);\n --grn-color-yellow9: hsl(52 49% 31%);\n --grn-color-yellow10: hsl(53 41% 26%);\n --grn-color-yellow11: hsl(54 34% 16%);\n --grn-color-yellow12: hsl(55 27% 8%);\n\n --grn-color-green1: hsl(97 58% 95%);\n --grn-color-green2: hsl(97 58% 88%);\n --grn-color-green3: hsl(95 55% 75%);\n --grn-color-green4: hsl(94 56% 62%);\n --grn-color-green5: hsl(92 51% 49%);\n --grn-color-green6: hsl(92 57% 42%);\n --grn-color-green7: hsl(92 60% 38%);\n --grn-color-green8: hsl(92 64% 34%);\n --grn-color-green9: hsl(92 73% 27%);\n --grn-color-green10: hsl(92 85% 21%);\n --grn-color-green11: hsl(92 94% 13%);\n --grn-color-green12: hsl(92 100% 8%);\n\n --grn-color-blue1: hsl(215 100% 96%);\n --grn-color-blue2: hsl(215 100% 90%);\n --grn-color-blue3: hsl(216 96% 82%);\n --grn-color-blue4: hsl(218 93% 71%);\n --grn-color-blue5: hsl(218 89% 59%);\n --grn-color-blue6: hsl(219 91% 48%);\n --grn-color-blue7: hsl(219 91% 41%);\n --grn-color-blue8: hsl(220 92% 35%);\n --grn-color-blue9: hsl(220 92% 29%);\n --grn-color-blue10: hsl(220 95% 22%);\n --grn-color-blue11: hsl(220 95% 15%);\n --grn-color-blue12: hsl(220 96% 9%);\n }\n\n :root {\n --core-s13: 3%;\n --core-s12: 3%;\n --core-s11: 3%;\n --core-s10: 3%;\n --core-s9: 3%;\n --core-s8: 4%;\n --core-s7: 5%;\n --core-s6: 8%;\n --core-s5: 9%;\n --core-s4: 12%;\n --core-s3: 14%;\n --core-s2: 18%;\n --core-s1: 18%;\n }\n\n :root {\n --sh-s13: var(--core-s13);\n --sh-s12: var(--core-s12);\n --sh-s11: var(--core-s11);\n --sh-s10: var(--core-s10);\n --sh-s9: var(--core-s9);\n --sh-s8: var(--core-s8);\n --sh-s7: var(--core-s7);\n --sh-s6: var(--core-s6);\n --sh-s5: var(--core-s5);\n --sh-s4: var(--core-s4);\n --sh-s3: var(--core-s3);\n --sh-s2: var(--core-s2);\n --sh-s1: var(--core-s1);\n }\n\n [data-theme='dark'], [data-theme='invert'] {\n --sh-s13: var(--core-s1);\n --sh-s12: var(--core-s2);\n --sh-s11: var(--core-s3);\n --sh-s10: var(--core-s4);\n --sh-s9: var(--core-s5);\n --sh-s8: var(--core-s6);\n --sh-s7: var(--core-s7);\n --sh-s6: var(--core-s8);\n --sh-s5: var(--core-s9);\n --sh-s4: var(--core-s10);\n --sh-s3: var(--core-s11);\n --sh-s2: var(--core-s12);\n --sh-s1: var(--core-s13);\n }\n\n :root, .grn-scope-next {\n --grn-color-shadeTone13: hsl(var(--sh-h) var(--sh-s13) 0%);\n --grn-color-shadeTone12: hsl(var(--sh-h) var(--sh-s12) 6%);\n --grn-color-shadeTone11: hsl(var(--sh-h) var(--sh-s11) 15%);\n --grn-color-shadeTone10: hsl(var(--sh-h) var(--sh-s10) 21%);\n --grn-color-shadeTone9: hsl(var(--sh-h) var(--sh-s9) 28%);\n --grn-color-shadeTone8: hsl(var(--sh-h) var(--sh-s8) 38%);\n --grn-color-shadeTone7: hsl(var(--sh-h) var(--sh-s7) 51%);\n --grn-color-shadeTone6: hsl(var(--sh-h) var(--sh-s6) 70%);\n --grn-color-shadeTone5: hsl(var(--sh-h) var(--sh-s5) 82%);\n --grn-color-shadeTone4: hsl(var(--sh-h) var(--sh-s4) 90%);\n --grn-color-shadeTone3: hsl(var(--sh-h) var(--sh-s3) 95%);\n --grn-color-shadeTone2: hsl(var(--sh-h) var(--sh-s2) 97.5%);\n --grn-color-shadeTone1: hsl(var(--sh-h) var(--sh-s1) 100%);\n\n --al-10: 73%;\n --al-9: 66%;\n --al-8: 59%;\n --al-7: 52%;\n --al-6: 45%;\n --al-5: 38%;\n --al-4: 31%;\n --al-3: 23%;\n --al-2: 15%;\n --al-1: 8%;\n\n --fds-10: 9%;\n --fds-9: 10%;\n --fds-8: 11%;\n --fds-7: 12%;\n --fds-6: 13%;\n --fds-5: 14%;\n --fds-4: 14%;\n --fds-3: 14%;\n --fds-2: 14%;\n --fds-1: 14%;\n\n --grn-color-lightFade10: hsl(var(--sh-h) var(--fds-1) var(--wf-l) / var(--al-10));\n --grn-color-lightFade9: hsl(var(--sh-h) var(--fds-2) var(--wf-l) / var(--al-9));\n --grn-color-lightFade8: hsl(var(--sh-h) var(--fds-3) var(--wf-l) / var(--al-8));\n --grn-color-lightFade7: hsl(var(--sh-h) var(--fds-4) var(--wf-l) / var(--al-7));\n --grn-color-lightFade6: hsl(var(--sh-h) var(--fds-5) var(--wf-l) / var(--al-6));\n --grn-color-lightFade5: hsl(var(--sh-h) var(--fds-6) var(--wf-l) / var(--al-5));\n --grn-color-lightFade4: hsl(var(--sh-h) var(--fds-7) var(--wf-l) / var(--al-4));\n --grn-color-lightFade3: hsl(var(--sh-h) var(--fds-8) var(--wf-l) / var(--al-3));\n --grn-color-lightFade2: hsl(var(--sh-h) var(--fds-9) var(--wf-l) / var(--al-2));\n --grn-color-lightFade1: hsl(var(--sh-h) var(--fds-10) var(--wf-l) / var(--al-1));\n\n --grn-color-darkFade10: hsl(var(--sh-h) var(--fds-10) var(--bf-l) / var(--al-10));\n --grn-color-darkFade9: hsl(var(--sh-h) var(--fds-9) var(--bf-l) / var(--al-9));\n --grn-color-darkFade8: hsl(var(--sh-h) var(--fds-8) var(--bf-l) / var(--al-8));\n --grn-color-darkFade7: hsl(var(--sh-h) var(--fds-7) var(--bf-l) / var(--al-7));\n --grn-color-darkFade6: hsl(var(--sh-h) var(--fds-6) var(--bf-l) / var(--al-6));\n --grn-color-darkFade5: hsl(var(--sh-h) var(--fds-5) var(--bf-l) / var(--al-5));\n --grn-color-darkFade4: hsl(var(--sh-h) var(--fds-4) var(--bf-l) / var(--al-4));\n --grn-color-darkFade3: hsl(var(--sh-h) var(--fds-3) var(--bf-l) / var(--al-3));\n --grn-color-darkFade2: hsl(var(--sh-h) var(--fds-2) var(--bf-l) / var(--al-2));\n --grn-color-darkFade1: hsl(var(--sh-h) var(--fds-1) var(--bf-l) / var(--al-1));\n }\n\n :root {\n --grn-color-warning: var(--grn-color-yellow4);\n --grn-color-danger: var(--grn-color-red7);\n --grn-color-success: var(--grn-color-green9);\n --grn-color-selection: var(--grn-color-blue6);\n }\n\n [data-theme] .grn-scope-next,\n .grn-scope-next {\n --sh-s:
|
|
1
|
+
const core = "\n :root {\n --sh-h: 60;\n --sh-s: 12%;\n --bf-l: 20%;\n --wf-l: calc(100% - var(--bf-l));\n }\n\n :root {\n --grn-color-red: var(--grn-color-red6);\n --grn-color-yellow: var(--grn-color-yellow5);\n --grn-color-green: var(--grn-color-green6);\n --grn-color-blue: var(--grn-color-blue6);\n }\n\n :root {\n --grn-color-red1: hsl(12 100% 97%);\n --grn-color-red2: hsl(12 100% 91%);\n --grn-color-red3: hsl(12 100% 82%);\n --grn-color-red4: hsl(12 99% 72%);\n --grn-color-red5: hsl(12 99% 63%);\n --grn-color-red6: hsl(13 97% 51%);\n --grn-color-red7: hsl(13 97% 42%);\n --grn-color-red8: hsl(7 98% 35%);\n --grn-color-red9: hsl(7 98% 28%);\n --grn-color-red10: hsl(5 99% 21%);\n --grn-color-red11: hsl(1 100% 15%);\n --grn-color-red12: hsl(357 100% 8%);\n\n --grn-color-yellow1: hsl(46 100% 95%);\n --grn-color-yellow2: hsl(47 97% 85%);\n --grn-color-yellow3: hsl(49 93% 73%);\n --grn-color-yellow4: hsl(51 89% 62%);\n --grn-color-yellow5: hsl(53 84% 48%);\n --grn-color-yellow6: hsl(53 77% 43%);\n --grn-color-yellow7: hsl(52 68% 37%);\n --grn-color-yellow8: hsl(52 58% 35%);\n --grn-color-yellow9: hsl(52 49% 31%);\n --grn-color-yellow10: hsl(53 41% 26%);\n --grn-color-yellow11: hsl(54 34% 16%);\n --grn-color-yellow12: hsl(55 27% 8%);\n\n --grn-color-green1: hsl(97 58% 95%);\n --grn-color-green2: hsl(97 58% 88%);\n --grn-color-green3: hsl(95 55% 75%);\n --grn-color-green4: hsl(94 56% 62%);\n --grn-color-green5: hsl(92 51% 49%);\n --grn-color-green6: hsl(92 57% 42%);\n --grn-color-green7: hsl(92 60% 38%);\n --grn-color-green8: hsl(92 64% 34%);\n --grn-color-green9: hsl(92 73% 27%);\n --grn-color-green10: hsl(92 85% 21%);\n --grn-color-green11: hsl(92 94% 13%);\n --grn-color-green12: hsl(92 100% 8%);\n\n --grn-color-blue1: hsl(215 100% 96%);\n --grn-color-blue2: hsl(215 100% 90%);\n --grn-color-blue3: hsl(216 96% 82%);\n --grn-color-blue4: hsl(218 93% 71%);\n --grn-color-blue5: hsl(218 89% 59%);\n --grn-color-blue6: hsl(219 91% 48%);\n --grn-color-blue7: hsl(219 91% 41%);\n --grn-color-blue8: hsl(220 92% 35%);\n --grn-color-blue9: hsl(220 92% 29%);\n --grn-color-blue10: hsl(220 95% 22%);\n --grn-color-blue11: hsl(220 95% 15%);\n --grn-color-blue12: hsl(220 96% 9%);\n }\n\n :root {\n --core-s13: 3%;\n --core-s12: 3%;\n --core-s11: 3%;\n --core-s10: 3%;\n --core-s9: 3%;\n --core-s8: 4%;\n --core-s7: 5%;\n --core-s6: 8%;\n --core-s5: 9%;\n --core-s4: 12%;\n --core-s3: 14%;\n --core-s2: 18%;\n --core-s1: 18%;\n }\n\n :root {\n --sh-s13: var(--core-s13);\n --sh-s12: var(--core-s12);\n --sh-s11: var(--core-s11);\n --sh-s10: var(--core-s10);\n --sh-s9: var(--core-s9);\n --sh-s8: var(--core-s8);\n --sh-s7: var(--core-s7);\n --sh-s6: var(--core-s6);\n --sh-s5: var(--core-s5);\n --sh-s4: var(--core-s4);\n --sh-s3: var(--core-s3);\n --sh-s2: var(--core-s2);\n --sh-s1: var(--core-s1);\n }\n\n [data-theme='dark'], [data-theme='invert'] {\n --sh-s13: var(--core-s1);\n --sh-s12: var(--core-s2);\n --sh-s11: var(--core-s3);\n --sh-s10: var(--core-s4);\n --sh-s9: var(--core-s5);\n --sh-s8: var(--core-s6);\n --sh-s7: var(--core-s7);\n --sh-s6: var(--core-s8);\n --sh-s5: var(--core-s9);\n --sh-s4: var(--core-s10);\n --sh-s3: var(--core-s11);\n --sh-s2: var(--core-s12);\n --sh-s1: var(--core-s13);\n }\n\n :root, .grn-scope-next {\n --grn-color-shadeTone13: hsl(var(--sh-h) var(--sh-s13) 0%);\n --grn-color-shadeTone12: hsl(var(--sh-h) var(--sh-s12) 6%);\n --grn-color-shadeTone11: hsl(var(--sh-h) var(--sh-s11) 15%);\n --grn-color-shadeTone10: hsl(var(--sh-h) var(--sh-s10) 21%);\n --grn-color-shadeTone9: hsl(var(--sh-h) var(--sh-s9) 28%);\n --grn-color-shadeTone8: hsl(var(--sh-h) var(--sh-s8) 38%);\n --grn-color-shadeTone7: hsl(var(--sh-h) var(--sh-s7) 51%);\n --grn-color-shadeTone6: hsl(var(--sh-h) var(--sh-s6) 70%);\n --grn-color-shadeTone5: hsl(var(--sh-h) var(--sh-s5) 82%);\n --grn-color-shadeTone4: hsl(var(--sh-h) var(--sh-s4) 90%);\n --grn-color-shadeTone3: hsl(var(--sh-h) var(--sh-s3) 95%);\n --grn-color-shadeTone2: hsl(var(--sh-h) var(--sh-s2) 97.5%);\n --grn-color-shadeTone1: hsl(var(--sh-h) var(--sh-s1) 100%);\n\n --al-10: 73%;\n --al-9: 66%;\n --al-8: 59%;\n --al-7: 52%;\n --al-6: 45%;\n --al-5: 38%;\n --al-4: 31%;\n --al-3: 23%;\n --al-2: 15%;\n --al-1: 8%;\n\n --fds-10: 9%;\n --fds-9: 10%;\n --fds-8: 11%;\n --fds-7: 12%;\n --fds-6: 13%;\n --fds-5: 14%;\n --fds-4: 14%;\n --fds-3: 14%;\n --fds-2: 14%;\n --fds-1: 14%;\n\n --grn-color-lightFade10: hsl(var(--sh-h) var(--fds-1) var(--wf-l) / var(--al-10));\n --grn-color-lightFade9: hsl(var(--sh-h) var(--fds-2) var(--wf-l) / var(--al-9));\n --grn-color-lightFade8: hsl(var(--sh-h) var(--fds-3) var(--wf-l) / var(--al-8));\n --grn-color-lightFade7: hsl(var(--sh-h) var(--fds-4) var(--wf-l) / var(--al-7));\n --grn-color-lightFade6: hsl(var(--sh-h) var(--fds-5) var(--wf-l) / var(--al-6));\n --grn-color-lightFade5: hsl(var(--sh-h) var(--fds-6) var(--wf-l) / var(--al-5));\n --grn-color-lightFade4: hsl(var(--sh-h) var(--fds-7) var(--wf-l) / var(--al-4));\n --grn-color-lightFade3: hsl(var(--sh-h) var(--fds-8) var(--wf-l) / var(--al-3));\n --grn-color-lightFade2: hsl(var(--sh-h) var(--fds-9) var(--wf-l) / var(--al-2));\n --grn-color-lightFade1: hsl(var(--sh-h) var(--fds-10) var(--wf-l) / var(--al-1));\n\n --grn-color-darkFade10: hsl(var(--sh-h) var(--fds-10) var(--bf-l) / var(--al-10));\n --grn-color-darkFade9: hsl(var(--sh-h) var(--fds-9) var(--bf-l) / var(--al-9));\n --grn-color-darkFade8: hsl(var(--sh-h) var(--fds-8) var(--bf-l) / var(--al-8));\n --grn-color-darkFade7: hsl(var(--sh-h) var(--fds-7) var(--bf-l) / var(--al-7));\n --grn-color-darkFade6: hsl(var(--sh-h) var(--fds-6) var(--bf-l) / var(--al-6));\n --grn-color-darkFade5: hsl(var(--sh-h) var(--fds-5) var(--bf-l) / var(--al-5));\n --grn-color-darkFade4: hsl(var(--sh-h) var(--fds-4) var(--bf-l) / var(--al-4));\n --grn-color-darkFade3: hsl(var(--sh-h) var(--fds-3) var(--bf-l) / var(--al-3));\n --grn-color-darkFade2: hsl(var(--sh-h) var(--fds-2) var(--bf-l) / var(--al-2));\n --grn-color-darkFade1: hsl(var(--sh-h) var(--fds-1) var(--bf-l) / var(--al-1));\n }\n\n :root {\n --grn-color-warning: var(--grn-color-yellow4);\n --grn-color-danger: var(--grn-color-red7);\n --grn-color-success: var(--grn-color-green9);\n --grn-color-selection: var(--grn-color-blue6);\n }\n\n [data-theme].grn-scope-next,\n [data-theme] .grn-scope-next,\n .grn-scope-next {\n --sh-s: 5%;\n --bf-l: 3%;\n --wf-l: calc(100% - var(--bf-l));\n\n --sh-s13: var(--sh-s);\n --sh-s12: var(--sh-s);\n --sh-s11: var(--sh-s);\n --sh-s10: var(--sh-s);\n --sh-s9: var(--sh-s);\n --sh-s8: calc(var(--sh-s) / 1.25);\n --sh-s7: calc(var(--sh-s) / 1.5);\n --sh-s6: calc(var(--sh-s) / 1.25);\n --sh-s5: var(--sh-s);\n --sh-s4: var(--sh-s);\n --sh-s3: var(--sh-s);\n --sh-s2: var(--sh-s);\n --sh-s1: var(--sh-s);\n\n --fds: 70%;\n\n --grn-color-lightFade10: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-10));\n --grn-color-lightFade9: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-9));\n --grn-color-lightFade8: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-8));\n --grn-color-lightFade7: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-7));\n --grn-color-lightFade6: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-6));\n --grn-color-lightFade5: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-5));\n --grn-color-lightFade4: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-4));\n --grn-color-lightFade3: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-3));\n --grn-color-lightFade2: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-2));\n --grn-color-lightFade1: hsl(var(--sh-h) var(--fds) var(--wf-l) / var(--al-1));\n\n --grn-color-darkFade10: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-10));\n --grn-color-darkFade9: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-9));\n --grn-color-darkFade8: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-8));\n --grn-color-darkFade7: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-7));\n --grn-color-darkFade6: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-6));\n --grn-color-darkFade5: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-5));\n --grn-color-darkFade4: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-4));\n --grn-color-darkFade3: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-3));\n --grn-color-darkFade2: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-2));\n --grn-color-darkFade1: hsl(var(--sh-h) var(--fds) var(--bf-l) / var(--al-1));\n\n --grn-color-overlay: color-mix(in hsl, var(--grn-color-fade1), transparent 50%);\n --grn-color-overlay2: var(--grn-color-fade1);\n\n --grn-field-background: var(--grn-color-overlay);\n\n --grn-color-overlayDanger: color-mix(in hsl, var(--grn-color-red7), transparent 93%);\n }\n";
|
|
2
2
|
export default core;
|