@flodesk/grain 11.46.1 → 11.47.1

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.
@@ -1,5 +1,5 @@
1
1
  import _styled from "@emotion/styled/base";
2
- const _excluded = ["children", "variant", "backgroundColor", "onClear", "hasClearButton"],
2
+ const _excluded = ["children", "variant", "backgroundColor", "onClear", "hasClearButton", "size"],
3
3
  _excluded2 = ["option", "isSelected", "menuItemsHaveEllipsis", "allowMultiple"],
4
4
  _excluded3 = ["children", "floating", "hasPortal", "isOpen"];
5
5
  import "core-js/modules/web.dom-collections.iterator.js";
@@ -34,12 +34,22 @@ const TriggerButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "p
34
34
  backgroundColor
35
35
  } = _ref;
36
36
  return getColor(backgroundColor ? backgroundColor : 'transparent');
37
- }, ";padding:0 var(--grn-field-paddingX);border:1px solid var(--grn-field-border-color);font-weight:", getWeight('normal'), ";min-height:var(--grn-textbox-height-m);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 : 'transparent')};\n  padding: 0 var(--grn-field-paddingX);\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textbox-height-m);\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(\n  ({ children, variant = 'box', backgroundColor, onClear, hasClearButton, ...props }, ref) => (\n    <>\n      {variant === 'box' && (\n        <TriggerButton ref={ref} type=\"button\" backgroundColor={backgroundColor} {...props}>\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}) => {\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          {...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}) => {\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            />\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};\n"]} */"));
37
+ }, ";padding-block:0;padding-inline:", _ref2 => {
38
+ let {
39
+ size
40
+ } = _ref2;
41
+ return "var(--grn-field-paddingX-".concat(size, ")");
42
+ }, ";border:1px solid var(--grn-field-border-color);font-weight:", getWeight('normal'), ";min-height:", _ref3 => {
43
+ let {
44
+ size
45
+ } = _ref3;
46
+ return "var(--grn-textbox-height-".concat(size, ")");
47
+ }, ";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 : 'transparent')};\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(\n  (\n    { children, variant = 'box', backgroundColor, onClear, hasClearButton, size, ...props },\n    ref,\n  ) => (\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"]} */"));
38
48
 
39
- const ClearButton = _ref2 => {
49
+ const ClearButton = _ref4 => {
40
50
  let {
41
51
  onClick
42
- } = _ref2;
52
+ } = _ref4;
43
53
 
44
54
  const handleClear = e => {
45
55
  e.stopPropagation();
@@ -52,20 +62,22 @@ const ClearButton = _ref2 => {
52
62
  });
53
63
  };
54
64
 
55
- const Trigger = /*#__PURE__*/forwardRef((_ref3, ref) => {
65
+ const Trigger = /*#__PURE__*/forwardRef((_ref5, ref) => {
56
66
  let {
57
67
  children,
58
68
  variant = 'box',
59
69
  backgroundColor,
60
70
  onClear,
61
- hasClearButton
62
- } = _ref3,
63
- props = _objectWithoutProperties(_ref3, _excluded);
71
+ hasClearButton,
72
+ size
73
+ } = _ref5,
74
+ props = _objectWithoutProperties(_ref5, _excluded);
64
75
 
65
76
  return ___EmotionJSX(React.Fragment, null, variant === 'box' && ___EmotionJSX(TriggerButton, _extends({
66
77
  ref: ref,
67
78
  type: "button",
68
- backgroundColor: backgroundColor
79
+ backgroundColor: backgroundColor,
80
+ size: size
69
81
  }, props), ___EmotionJSX(Text, {
70
82
  hasEllipsis: true
71
83
  }, children), ___EmotionJSX(Arrange, {
@@ -97,7 +109,7 @@ const getTriggerContent = (isMultiple, selected, placeholder) => {
97
109
  return selected.content;
98
110
  };
99
111
 
100
- const SelectButton = _ref4 => {
112
+ const SelectButton = _ref6 => {
101
113
  let {
102
114
  customTrigger,
103
115
  variant,
@@ -105,8 +117,9 @@ const SelectButton = _ref4 => {
105
117
  selected,
106
118
  placeholder,
107
119
  backgroundColor,
108
- onClear
109
- } = _ref4;
120
+ onClear,
121
+ size
122
+ } = _ref6;
110
123
  const props = {
111
124
  variant,
112
125
  children: getTriggerContent(isMultiple, selected, placeholder)
@@ -119,7 +132,8 @@ const SelectButton = _ref4 => {
119
132
  }) : ___EmotionJSX(Trigger, _extends({
120
133
  backgroundColor: backgroundColor,
121
134
  onClear: onClear,
122
- hasClearButton: hasClearButton
135
+ hasClearButton: hasClearButton,
136
+ size: size
123
137
  }, props)));
124
138
  };
125
139
 
@@ -134,27 +148,27 @@ const Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
134
148
  } : {
135
149
  name: "wowqs1",
136
150
  styles: "min-width:0px",
137
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/select.jsx"],"names":[],"mappings":"AAwHuB","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 : 'transparent')};\n  padding: 0 var(--grn-field-paddingX);\n  border: 1px solid var(--grn-field-border-color);\n  font-weight: ${getWeight('normal')};\n  min-height: var(--grn-textbox-height-m);\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(\n  ({ children, variant = 'box', backgroundColor, onClear, hasClearButton, ...props }, ref) => (\n    <>\n      {variant === 'box' && (\n        <TriggerButton ref={ref} type=\"button\" backgroundColor={backgroundColor} {...props}>\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}) => {\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          {...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}) => {\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            />\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};\n"]} */",
151
+ 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 : 'transparent')};\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(\n  (\n    { children, variant = 'box', backgroundColor, onClear, hasClearButton, size, ...props },\n    ref,\n  ) => (\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"]} */",
138
152
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
139
153
  });
140
154
 
141
- const SelectMenuOption = _ref5 => {
155
+ const SelectMenuOption = _ref7 => {
142
156
  let {
143
157
  option,
144
158
  isSelected,
145
159
  menuItemsHaveEllipsis,
146
160
  allowMultiple
147
- } = _ref5,
148
- props = _objectWithoutProperties(_ref5, _excluded2);
161
+ } = _ref7,
162
+ props = _objectWithoutProperties(_ref7, _excluded2);
149
163
 
150
164
  return ___EmotionJSX(Listbox.Option, _extends({
151
165
  value: option,
152
166
  as: Fragment,
153
167
  disabled: option.isDisabled
154
- }, props), _ref6 => {
168
+ }, props), _ref8 => {
155
169
  let {
156
170
  active
157
- } = _ref6;
171
+ } = _ref8;
158
172
  return ___EmotionJSX(MenuItem, {
159
173
  isSelected: isSelected,
160
174
  isActive: active,
@@ -164,11 +178,11 @@ const SelectMenuOption = _ref5 => {
164
178
  });
165
179
  };
166
180
 
167
- const SelectInfo = _ref7 => {
181
+ const SelectInfo = _ref9 => {
168
182
  let {
169
183
  label,
170
184
  hint
171
- } = _ref7;
185
+ } = _ref9;
172
186
  return ___EmotionJSX(React.Fragment, null, (label || hint) && ___EmotionJSX(Box, {
173
187
  marginBottom: "var(--grn-form-control-label-gap)"
174
188
  }, label && ___EmotionJSX(Listbox.Label, {
@@ -176,14 +190,14 @@ const SelectInfo = _ref7 => {
176
190
  }, label), hint && ___EmotionJSX(FieldHint, null, hint)));
177
191
  };
178
192
 
179
- const SelectMenu = _ref8 => {
193
+ const SelectMenu = _ref10 => {
180
194
  let {
181
195
  children,
182
196
  floating,
183
197
  hasPortal,
184
198
  isOpen
185
- } = _ref8,
186
- props = _objectWithoutProperties(_ref8, _excluded3);
199
+ } = _ref10,
200
+ props = _objectWithoutProperties(_ref10, _excluded3);
187
201
 
188
202
  const Root = hasPortal ? FloatingPortal : Fragment;
189
203
  return ___EmotionJSX(Root, null, ___EmotionJSX(MenuCardTransition, null, ___EmotionJSX(Listbox.Options, _extends({
@@ -204,7 +218,7 @@ const getIsSelected = (isMultiple, option, selected) => {
204
218
  return option.value === selected.value;
205
219
  };
206
220
 
207
- export const Select = _ref9 => {
221
+ export const Select = _ref11 => {
208
222
  let {
209
223
  options,
210
224
  value,
@@ -223,8 +237,9 @@ export const Select = _ref9 => {
223
237
  placeholder,
224
238
  isDisabled,
225
239
  backgroundColor,
226
- onClear
227
- } = _ref9;
240
+ onClear,
241
+ size = 'm'
242
+ } = _ref11;
228
243
  const {
229
244
  reference,
230
245
  floating,
@@ -262,10 +277,10 @@ export const Select = _ref9 => {
262
277
  width: rootWidth,
263
278
  multiple: allowMultiple,
264
279
  disabled: isDisabled
265
- }, _ref10 => {
280
+ }, _ref12 => {
266
281
  let {
267
282
  open
268
- } = _ref10;
283
+ } = _ref12;
269
284
  return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(SelectInfo, {
270
285
  label: label,
271
286
  hint: hint
@@ -279,7 +294,8 @@ export const Select = _ref9 => {
279
294
  selected: selected,
280
295
  placeholder: placeholder,
281
296
  backgroundColor: backgroundColor,
282
- onClear: onClear
297
+ onClear: onClear,
298
+ size: size
283
299
  }), ___EmotionJSX(SelectMenu, {
284
300
  placement: menuPlacement,
285
301
  maxHeight: menuMaxHeight,
@@ -324,5 +340,6 @@ Select.propTypes = {
324
340
  placeholder: PropTypes.string,
325
341
  isDisabled: PropTypes.bool,
326
342
  backgroundColor: types.color,
327
- onClear: PropTypes.func
343
+ onClear: PropTypes.func,
344
+ size: PropTypes.oneOf(['m', 'l'])
328
345
  };
@@ -1,7 +1,7 @@
1
1
  import _styled from "@emotion/styled/base";
2
- const _excluded = ["children", "internalType", "setInternalType"],
2
+ const _excluded = ["children", "internalType", "setInternalType", "size"],
3
3
  _excluded2 = ["children"],
4
- _excluded3 = ["value", "placeholder", "label", "id", "icon", "hasError", "errorMessage", "isReadOnly", "isDisabled", "type", "hint", "onClear", "backgroundColor"];
4
+ _excluded3 = ["value", "placeholder", "label", "id", "icon", "hasError", "errorMessage", "isReadOnly", "isDisabled", "type", "hint", "onClear", "backgroundColor", "size"];
5
5
  import "core-js/modules/web.dom-collections.iterator.js";
6
6
 
7
7
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
@@ -27,13 +27,14 @@ const IconSection = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produc
27
27
  } : {
28
28
  target: "e1o9e51y0",
29
29
  label: "IconSection"
30
- })("position:absolute;margin:auto;left:", iconOffset, ";top:0;bottom:0;height:fit-content;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtaW5wdXQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWE4QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy90ZXh0LWlucHV0LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgQm94LCBUZXh0IH0gZnJvbSAnLic7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnLi9pY29uJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuL2ljb24tYnV0dG9uJztcbmltcG9ydCB7IEZpZWxkQ2xlYXJCdXR0b24sIEZpZWxkSGludCwgRmllbGRMYWJlbCwgSW5wdXRGaWVsZCB9IGZyb20gJy4uL2ZvdW5kYXRpb25hbCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IEljb25IaWRlLCBJY29uU2hvdyB9IGZyb20gJy4uL2ljb25zJztcblxuY29uc3QgaWNvbk9mZnNldCA9ICd2YXIoLS1ncm4tZmllbGQtcGFkZGluZ1gpJztcbmNvbnN0IGljb25UZXh0R2FwID0gJ3ZhcigtLWdybi1zcGFjZS1zKSc7XG5cbmNvbnN0IEljb25TZWN0aW9uID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBtYXJnaW46IGF1dG87XG4gIGxlZnQ6ICR7aWNvbk9mZnNldH07XG4gIHRvcDogMDtcbiAgYm90dG9tOiAwO1xuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbmA7XG5cbmNvbnN0IEFjdGlvbkJ1dHRvbldyYXBwZXIgPSAoeyBjaGlsZHJlbiB9KSA9PiB7XG4gIGNvbnN0IHJpZ2h0T2Zmc2V0ID0gYGNhbGMoKHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKSAtIHZhcigtLWdybi1jbGVhcmJ1dHRvbi1oZWlnaHQpKSAvIDIpYDtcbiAgcmV0dXJuIChcbiAgICA8Qm94XG4gICAgICBwb3NpdGlvbj1cImFic29sdXRlXCJcbiAgICAgIHJpZ2h0PXtyaWdodE9mZnNldH1cbiAgICAgIHRvcD1cIjBcIlxuICAgICAgYm90dG9tPVwiMFwiXG4gICAgICBtYXJnaW49XCJhdXRvXCJcbiAgICAgIGhlaWdodD1cImZpdC1jb250ZW50XCJcbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Cb3g+XG4gICk7XG59O1xuXG5jb25zdCBWaXNpYmlsaXR5QnV0dG9uID0gKHsgY2hpbGRyZW4sIGludGVybmFsVHlwZSwgc2V0SW50ZXJuYWxUeXBlLCAuLi5wcm9wcyB9KSA9PiB7XG4gIGNvbnN0IHR5cGVBbmRJY29uTWFwID0ge1xuICAgIHBhc3N3b3JkOiA8SWNvblNob3cgLz4sXG4gICAgdGV4dDogPEljb25IaWRlIC8+LFxuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPEFjdGlvbkJ1dHRvbldyYXBwZXI+XG4gICAgICA8SWNvbkJ1dHRvblxuICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgIGljb249e3R5cGVBbmRJY29uTWFwW2ludGVybmFsVHlwZV19XG4gICAgICAgIG9uQ2xpY2s9eygpID0+IHNldEludGVybmFsVHlwZShpbnRlcm5hbFR5cGUgPT09ICd0ZXh0JyA/ICdwYXNzd29yZCcgOiAndGV4dCcpfVxuICAgICAgLz5cbiAgICA8L0FjdGlvbkJ1dHRvbldyYXBwZXI+XG4gICk7XG59O1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9ICh7IG9uQ2xpY2sgfSkgPT4gKFxuICA8QWN0aW9uQnV0dG9uV3JhcHBlcj5cbiAgICA8RmllbGRDbGVhckJ1dHRvbiBvbkNsaWNrPXtvbkNsaWNrfSAvPlxuICA8L0FjdGlvbkJ1dHRvbldyYXBwZXI+XG4pO1xuXG5leHBvcnQgY29uc3QgVGV4dElucHV0TGFiZWwgPSAoeyBjaGlsZHJlbiwgLi4ucHJvcHMgfSkgPT4gKFxuICA8RmllbGRMYWJlbCB7Li4ucHJvcHN9PntjaGlsZHJlbn08L0ZpZWxkTGFiZWw+XG4pO1xuXG5leHBvcnQgY29uc3QgVGV4dElucHV0ID0gUmVhY3QuZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHZhbHVlLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICBsYWJlbCxcbiAgICAgIGlkLFxuICAgICAgaWNvbixcbiAgICAgIGhhc0Vycm9yLFxuICAgICAgZXJyb3JNZXNzYWdlLFxuICAgICAgaXNSZWFkT25seSxcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICB0eXBlID0gJ3RleHQnLFxuICAgICAgaGludCxcbiAgICAgIG9uQ2xlYXIsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3IsXG4gICAgICAuLi5wcm9wc1xuICAgIH0sXG4gICAgcmVmLFxuICApID0+IHtcbiAgICBjb25zdCBbaW50ZXJuYWxUeXBlLCBzZXRJbnRlcm5hbFR5cGVdID0gUmVhY3QudXNlU3RhdGUodHlwZSk7XG5cbiAgICBjb25zdCBpY29uV2lkdGggPSBpY29uPy50eXBlPy52aWV3Qm94V2lkdGggLyAyIHx8IDE2O1xuICAgIGNvbnN0IGhhc1Zpc2liaWxpdHlCdXR0b24gPSB0eXBlID09PSAncGFzc3dvcmQnICYmICFpc1JlYWRPbmx5ICYmICFpc0Rpc2FibGVkO1xuICAgIGNvbnN0IGhhc0NsZWFyQnV0dG9uID0gb25DbGVhciAmJiAhaXNSZWFkT25seSAmJiAhaXNEaXNhYmxlZDtcbiAgICBjb25zdCBoYXNCdXR0b24gPSBoYXNWaXNpYmlsaXR5QnV0dG9uIHx8IGhhc0NsZWFyQnV0dG9uO1xuICAgIGNvbnN0IHBhZGRpbmdMZWZ0ID0gaWNvbiA/IGBjYWxjKCR7aWNvbk9mZnNldH0gKyAke2ljb25XaWR0aH1weCArICR7aWNvblRleHRHYXB9KWAgOiB1bmRlZmluZWQ7XG4gICAgY29uc3QgcGFkZGluZ1JpZ2h0ID0gaGFzQnV0dG9uID8gJ3ZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKScgOiB1bmRlZmluZWQ7XG5cbiAgICBjb25zdCBmaWVsZE1hcmdpblRvcCA9IGxhYmVsIHx8IGhpbnQgPyAndmFyKC0tZ3JuLWZvcm0tY29udHJvbC1sYWJlbC1nYXApJyA6IHVuZGVmaW5lZDtcblxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2PlxuICAgICAgICB7bGFiZWwgJiYgPEZpZWxkTGFiZWwgaHRtbEZvcj17aWR9PntsYWJlbH08L0ZpZWxkTGFiZWw+fVxuICAgICAgICB7aGludCAmJiA8RmllbGRIaW50PntoaW50fTwvRmllbGRIaW50Pn1cbiAgICAgICAgPEJveCBwb3NpdGlvbj1cInJlbGF0aXZlXCIgbWFyZ2luVG9wPXtmaWVsZE1hcmdpblRvcH0+XG4gICAgICAgICAge2ljb24gJiYgKFxuICAgICAgICAgICAgPEljb25TZWN0aW9uPlxuICAgICAgICAgICAgICA8SWNvbiBpY29uPXtpY29ufSAvPlxuICAgICAgICAgICAgPC9JY29uU2VjdGlvbj5cbiAgICAgICAgICApfVxuICAgICAgICAgIDxJbnB1dEZpZWxkXG4gICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIHR5cGU9e2ludGVybmFsVHlwZX1cbiAgICAgICAgICAgIGlkPXtpZH1cbiAgICAgICAgICAgIHZhbHVlPXt2YWx1ZX1cbiAgICAgICAgICAgIHBsYWNlaG9sZGVyPXtwbGFjZWhvbGRlcn1cbiAgICAgICAgICAgIHBhZGRpbmdMZWZ0PXtwYWRkaW5nTGVmdH1cbiAgICAgICAgICAgIHBhZGRpbmdSaWdodD17cGFkZGluZ1JpZ2h0fVxuICAgICAgICAgICAgaGFzRXJyb3I9e2hhc0Vycm9yfVxuICAgICAgICAgICAgaXNSZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgICAgICAgIHsuLi5wcm9wc31cbiAgICAgICAgICAvPlxuICAgICAgICAgIHtoYXNWaXNpYmlsaXR5QnV0dG9uICYmIChcbiAgICAgICAgICAgIDxWaXNpYmlsaXR5QnV0dG9uIHNldEludGVybmFsVHlwZT17c2V0SW50ZXJuYWxUeXBlfSBpbnRlcm5hbFR5cGU9e2ludGVybmFsVHlwZX0gLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtoYXNDbGVhckJ1dHRvbiAmJiB2YWx1ZSAmJiA8Q2xlYXJCdXR0b24gb25DbGljaz17b25DbGVhcn0gLz59XG4gICAgICAgIDwvQm94PlxuICAgICAgICB7ZXJyb3JNZXNzYWdlICYmIChcbiAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cInZhcigtLWdybi1mb3JtLWNvbnRyb2wtbGFiZWwtZ2FwKVwiPlxuICAgICAgICAgICAgPFRleHQgY29sb3I9XCJkYW5nZXJcIj57ZXJyb3JNZXNzYWdlfTwvVGV4dD5cbiAgICAgICAgICA8L0JveD5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH0sXG4pO1xuXG5UZXh0SW5wdXQuTGFiZWwgPSBUZXh0SW5wdXRMYWJlbDtcblRleHRJbnB1dC5IaW50ID0gRmllbGRIaW50O1xuXG5UZXh0SW5wdXQucHJvcFR5cGVzID0ge1xuICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICBwbGFjZWhvbGRlcjogUHJvcFR5cGVzLnN0cmluZyxcbiAgdmFsdWU6IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5udW1iZXJdKSxcbiAgbGFiZWw6IHR5cGVzLmxhYmVsLFxuICBpY29uOiBQcm9wVHlwZXMubm9kZSxcbiAgaGFzRXJyb3I6IFByb3BUeXBlcy5ib29sLFxuICBlcnJvck1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGlzUmVhZE9ubHk6IFByb3BUeXBlcy5ib29sLFxuICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgdHlwZTogdHlwZXMudGV4dElucHV0LFxuICBoaW50OiB0eXBlcy5oaW50LFxuICBiYWNrZ3JvdW5kQ29sb3I6IHR5cGVzLmNvbG9yLFxuICBvbkNsZWFyOiBQcm9wVHlwZXMuZnVuYyxcbn07XG4iXX0= */"));
30
+ })("position:absolute;margin:auto;left:", iconOffset, ";top:0;bottom:0;height:fit-content;pointer-events:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtaW5wdXQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWE4QiIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy90ZXh0LWlucHV0LmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgQm94LCBUZXh0IH0gZnJvbSAnLic7XG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnLi9pY29uJztcbmltcG9ydCB7IEljb25CdXR0b24gfSBmcm9tICcuL2ljb24tYnV0dG9uJztcbmltcG9ydCB7IEZpZWxkQ2xlYXJCdXR0b24sIEZpZWxkSGludCwgRmllbGRMYWJlbCwgSW5wdXRGaWVsZCB9IGZyb20gJy4uL2ZvdW5kYXRpb25hbCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IEljb25IaWRlLCBJY29uU2hvdyB9IGZyb20gJy4uL2ljb25zJztcblxuY29uc3QgaWNvbk9mZnNldCA9ICd2YXIoLS1ncm4tZmllbGQtcGFkZGluZ1gpJztcbmNvbnN0IGljb25UZXh0R2FwID0gJ3ZhcigtLWdybi1zcGFjZS1zKSc7XG5cbmNvbnN0IEljb25TZWN0aW9uID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBtYXJnaW46IGF1dG87XG4gIGxlZnQ6ICR7aWNvbk9mZnNldH07XG4gIHRvcDogMDtcbiAgYm90dG9tOiAwO1xuICBoZWlnaHQ6IGZpdC1jb250ZW50O1xuICBwb2ludGVyLWV2ZW50czogbm9uZTtcbmA7XG5cbmNvbnN0IEFjdGlvbkJ1dHRvbldyYXBwZXIgPSAoeyBjaGlsZHJlbiwgc2l6ZSB9KSA9PiB7XG4gIGNvbnN0IHJpZ2h0T2Zmc2V0ID0gYGNhbGMoKHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC0ke3NpemV9KSAtIHZhcigtLWdybi1jbGVhcmJ1dHRvbi1oZWlnaHQpKSAvIDIpYDtcbiAgcmV0dXJuIChcbiAgICA8Qm94XG4gICAgICBwb3NpdGlvbj1cImFic29sdXRlXCJcbiAgICAgIHJpZ2h0PXtyaWdodE9mZnNldH1cbiAgICAgIHRvcD1cIjBcIlxuICAgICAgYm90dG9tPVwiMFwiXG4gICAgICBtYXJnaW49XCJhdXRvXCJcbiAgICAgIGhlaWdodD1cImZpdC1jb250ZW50XCJcbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9Cb3g+XG4gICk7XG59O1xuXG5jb25zdCBWaXNpYmlsaXR5QnV0dG9uID0gKHsgY2hpbGRyZW4sIGludGVybmFsVHlwZSwgc2V0SW50ZXJuYWxUeXBlLCBzaXplLCAuLi5wcm9wcyB9KSA9PiB7XG4gIGNvbnN0IHR5cGVBbmRJY29uTWFwID0ge1xuICAgIHBhc3N3b3JkOiA8SWNvblNob3cgLz4sXG4gICAgdGV4dDogPEljb25IaWRlIC8+LFxuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPEFjdGlvbkJ1dHRvbldyYXBwZXIgc2l6ZT17c2l6ZX0+XG4gICAgICA8SWNvbkJ1dHRvblxuICAgICAgICB7Li4ucHJvcHN9XG4gICAgICAgIGljb249e3R5cGVBbmRJY29uTWFwW2ludGVybmFsVHlwZV19XG4gICAgICAgIG9uQ2xpY2s9eygpID0+IHNldEludGVybmFsVHlwZShpbnRlcm5hbFR5cGUgPT09ICd0ZXh0JyA/ICdwYXNzd29yZCcgOiAndGV4dCcpfVxuICAgICAgLz5cbiAgICA8L0FjdGlvbkJ1dHRvbldyYXBwZXI+XG4gICk7XG59O1xuXG5jb25zdCBDbGVhckJ1dHRvbiA9ICh7IG9uQ2xpY2ssIHNpemUgfSkgPT4gKFxuICA8QWN0aW9uQnV0dG9uV3JhcHBlciBzaXplPXtzaXplfT5cbiAgICA8RmllbGRDbGVhckJ1dHRvbiBvbkNsaWNrPXtvbkNsaWNrfSAvPlxuICA8L0FjdGlvbkJ1dHRvbldyYXBwZXI+XG4pO1xuXG5leHBvcnQgY29uc3QgVGV4dElucHV0TGFiZWwgPSAoeyBjaGlsZHJlbiwgLi4ucHJvcHMgfSkgPT4gKFxuICA8RmllbGRMYWJlbCB7Li4ucHJvcHN9PntjaGlsZHJlbn08L0ZpZWxkTGFiZWw+XG4pO1xuXG5leHBvcnQgY29uc3QgVGV4dElucHV0ID0gUmVhY3QuZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHZhbHVlLFxuICAgICAgcGxhY2Vob2xkZXIsXG4gICAgICBsYWJlbCxcbiAgICAgIGlkLFxuICAgICAgaWNvbixcbiAgICAgIGhhc0Vycm9yLFxuICAgICAgZXJyb3JNZXNzYWdlLFxuICAgICAgaXNSZWFkT25seSxcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICB0eXBlID0gJ3RleHQnLFxuICAgICAgaGludCxcbiAgICAgIG9uQ2xlYXIsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3IsXG4gICAgICBzaXplID0gJ20nLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgW2ludGVybmFsVHlwZSwgc2V0SW50ZXJuYWxUeXBlXSA9IFJlYWN0LnVzZVN0YXRlKHR5cGUpO1xuXG4gICAgY29uc3QgaWNvbldpZHRoID0gaWNvbj8udHlwZT8udmlld0JveFdpZHRoIC8gMiB8fCAxNjtcbiAgICBjb25zdCBoYXNWaXNpYmlsaXR5QnV0dG9uID0gdHlwZSA9PT0gJ3Bhc3N3b3JkJyAmJiAhaXNSZWFkT25seSAmJiAhaXNEaXNhYmxlZDtcbiAgICBjb25zdCBoYXNDbGVhckJ1dHRvbiA9IG9uQ2xlYXIgJiYgIWlzUmVhZE9ubHkgJiYgIWlzRGlzYWJsZWQ7XG4gICAgY29uc3QgaGFzQnV0dG9uID0gaGFzVmlzaWJpbGl0eUJ1dHRvbiB8fCBoYXNDbGVhckJ1dHRvbjtcbiAgICBjb25zdCBwYWRkaW5nTGVmdCA9IGljb24gPyBgY2FsYygke2ljb25PZmZzZXR9ICsgJHtpY29uV2lkdGh9cHggKyAke2ljb25UZXh0R2FwfSlgIDogdW5kZWZpbmVkO1xuICAgIGNvbnN0IHBhZGRpbmdSaWdodCA9IGhhc0J1dHRvbiA/IGB2YXIoLS1ncm4tdGV4dGJveC1oZWlnaHQtJHtzaXplfSlgIDogdW5kZWZpbmVkO1xuXG4gICAgY29uc3QgZmllbGRNYXJnaW5Ub3AgPSBsYWJlbCB8fCBoaW50ID8gJ3ZhcigtLWdybi1mb3JtLWNvbnRyb2wtbGFiZWwtZ2FwKScgOiB1bmRlZmluZWQ7XG5cbiAgICByZXR1cm4gKFxuICAgICAgPGRpdj5cbiAgICAgICAge2xhYmVsICYmIDxGaWVsZExhYmVsIGh0bWxGb3I9e2lkfT57bGFiZWx9PC9GaWVsZExhYmVsPn1cbiAgICAgICAge2hpbnQgJiYgPEZpZWxkSGludD57aGludH08L0ZpZWxkSGludD59XG4gICAgICAgIDxCb3ggcG9zaXRpb249XCJyZWxhdGl2ZVwiIG1hcmdpblRvcD17ZmllbGRNYXJnaW5Ub3B9PlxuICAgICAgICAgIHtpY29uICYmIChcbiAgICAgICAgICAgIDxJY29uU2VjdGlvbj5cbiAgICAgICAgICAgICAgPEljb24gaWNvbj17aWNvbn0gLz5cbiAgICAgICAgICAgIDwvSWNvblNlY3Rpb24+XG4gICAgICAgICAgKX1cbiAgICAgICAgICA8SW5wdXRGaWVsZFxuICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICB0eXBlPXtpbnRlcm5hbFR5cGV9XG4gICAgICAgICAgICBpZD17aWR9XG4gICAgICAgICAgICB2YWx1ZT17dmFsdWV9XG4gICAgICAgICAgICBwbGFjZWhvbGRlcj17cGxhY2Vob2xkZXJ9XG4gICAgICAgICAgICBwYWRkaW5nTGVmdD17cGFkZGluZ0xlZnR9XG4gICAgICAgICAgICBwYWRkaW5nUmlnaHQ9e3BhZGRpbmdSaWdodH1cbiAgICAgICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgICAgIGlzUmVhZE9ubHk9e2lzUmVhZE9ubHl9XG4gICAgICAgICAgICBpc0Rpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgey4uLnByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2hhc1Zpc2liaWxpdHlCdXR0b24gJiYgKFxuICAgICAgICAgICAgPFZpc2liaWxpdHlCdXR0b25cbiAgICAgICAgICAgICAgc2V0SW50ZXJuYWxUeXBlPXtzZXRJbnRlcm5hbFR5cGV9XG4gICAgICAgICAgICAgIGludGVybmFsVHlwZT17aW50ZXJuYWxUeXBlfVxuICAgICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApfVxuICAgICAgICAgIHtoYXNDbGVhckJ1dHRvbiAmJiB2YWx1ZSAmJiA8Q2xlYXJCdXR0b24gb25DbGljaz17b25DbGVhcn0gc2l6ZT17c2l6ZX0gLz59XG4gICAgICAgIDwvQm94PlxuICAgICAgICB7ZXJyb3JNZXNzYWdlICYmIChcbiAgICAgICAgICA8Qm94IG1hcmdpblRvcD1cInZhcigtLWdybi1mb3JtLWNvbnRyb2wtbGFiZWwtZ2FwKVwiPlxuICAgICAgICAgICAgPFRleHQgY29sb3I9XCJkYW5nZXJcIj57ZXJyb3JNZXNzYWdlfTwvVGV4dD5cbiAgICAgICAgICA8L0JveD5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgICk7XG4gIH0sXG4pO1xuXG5UZXh0SW5wdXQuTGFiZWwgPSBUZXh0SW5wdXRMYWJlbDtcblRleHRJbnB1dC5IaW50ID0gRmllbGRIaW50O1xuXG5UZXh0SW5wdXQucHJvcFR5cGVzID0ge1xuICBpZDogUHJvcFR5cGVzLnN0cmluZy5pc1JlcXVpcmVkLFxuICBwbGFjZWhvbGRlcjogUHJvcFR5cGVzLnN0cmluZyxcbiAgdmFsdWU6IFByb3BUeXBlcy5vbmVPZlR5cGUoW1Byb3BUeXBlcy5zdHJpbmcsIFByb3BUeXBlcy5udW1iZXJdKSxcbiAgbGFiZWw6IHR5cGVzLmxhYmVsLFxuICBpY29uOiBQcm9wVHlwZXMubm9kZSxcbiAgaGFzRXJyb3I6IFByb3BUeXBlcy5ib29sLFxuICBlcnJvck1lc3NhZ2U6IFByb3BUeXBlcy5zdHJpbmcsXG4gIGlzUmVhZE9ubHk6IFByb3BUeXBlcy5ib29sLFxuICBpc0Rpc2FibGVkOiBQcm9wVHlwZXMuYm9vbCxcbiAgdHlwZTogdHlwZXMudGV4dElucHV0LFxuICBoaW50OiB0eXBlcy5oaW50LFxuICBiYWNrZ3JvdW5kQ29sb3I6IHR5cGVzLmNvbG9yLFxuICBvbkNsZWFyOiBQcm9wVHlwZXMuZnVuYyxcbiAgc2l6ZTogUHJvcFR5cGVzLm9uZU9mKFsnbScsICdsJ10pLFxufTtcbiJdfQ== */"));
31
31
 
32
32
  const ActionButtonWrapper = _ref => {
33
33
  let {
34
- children
34
+ children,
35
+ size
35
36
  } = _ref;
36
- const rightOffset = "calc((var(--grn-textbox-height-m) - var(--grn-clearbutton-height)) / 2)";
37
+ const rightOffset = "calc((var(--grn-textbox-height-".concat(size, ") - var(--grn-clearbutton-height)) / 2)");
37
38
  return ___EmotionJSX(Box, {
38
39
  position: "absolute",
39
40
  right: rightOffset,
@@ -48,7 +49,8 @@ const VisibilityButton = _ref2 => {
48
49
  let {
49
50
  children,
50
51
  internalType,
51
- setInternalType
52
+ setInternalType,
53
+ size
52
54
  } = _ref2,
53
55
  props = _objectWithoutProperties(_ref2, _excluded);
54
56
 
@@ -56,7 +58,9 @@ const VisibilityButton = _ref2 => {
56
58
  password: ___EmotionJSX(IconShow, null),
57
59
  text: ___EmotionJSX(IconHide, null)
58
60
  };
59
- return ___EmotionJSX(ActionButtonWrapper, null, ___EmotionJSX(IconButton, _extends({}, props, {
61
+ return ___EmotionJSX(ActionButtonWrapper, {
62
+ size: size
63
+ }, ___EmotionJSX(IconButton, _extends({}, props, {
60
64
  icon: typeAndIconMap[internalType],
61
65
  onClick: () => setInternalType(internalType === 'text' ? 'password' : 'text')
62
66
  })));
@@ -64,9 +68,12 @@ const VisibilityButton = _ref2 => {
64
68
 
65
69
  const ClearButton = _ref3 => {
66
70
  let {
67
- onClick
71
+ onClick,
72
+ size
68
73
  } = _ref3;
69
- return ___EmotionJSX(ActionButtonWrapper, null, ___EmotionJSX(FieldClearButton, {
74
+ return ___EmotionJSX(ActionButtonWrapper, {
75
+ size: size
76
+ }, ___EmotionJSX(FieldClearButton, {
70
77
  onClick: onClick
71
78
  }));
72
79
  };
@@ -95,7 +102,8 @@ export const TextInput = /*#__PURE__*/React.forwardRef((_ref5, ref) => {
95
102
  type = 'text',
96
103
  hint,
97
104
  onClear,
98
- backgroundColor
105
+ backgroundColor,
106
+ size = 'm'
99
107
  } = _ref5,
100
108
  props = _objectWithoutProperties(_ref5, _excluded3);
101
109
 
@@ -105,7 +113,7 @@ export const TextInput = /*#__PURE__*/React.forwardRef((_ref5, ref) => {
105
113
  const hasClearButton = onClear && !isReadOnly && !isDisabled;
106
114
  const hasButton = hasVisibilityButton || hasClearButton;
107
115
  const paddingLeft = icon ? "calc(".concat(iconOffset, " + ").concat(iconWidth, "px + ").concat(iconTextGap, ")") : undefined;
108
- const paddingRight = hasButton ? 'var(--grn-textbox-height-m)' : undefined;
116
+ const paddingRight = hasButton ? "var(--grn-textbox-height-".concat(size, ")") : undefined;
109
117
  const fieldMarginTop = label || hint ? 'var(--grn-form-control-label-gap)' : undefined;
110
118
  return ___EmotionJSX("div", null, label && ___EmotionJSX(FieldLabel, {
111
119
  htmlFor: id
@@ -125,12 +133,15 @@ export const TextInput = /*#__PURE__*/React.forwardRef((_ref5, ref) => {
125
133
  hasError: hasError,
126
134
  isReadOnly: isReadOnly,
127
135
  isDisabled: isDisabled,
128
- backgroundColor: backgroundColor
136
+ backgroundColor: backgroundColor,
137
+ size: size
129
138
  }, props)), hasVisibilityButton && ___EmotionJSX(VisibilityButton, {
130
139
  setInternalType: setInternalType,
131
- internalType: internalType
140
+ internalType: internalType,
141
+ size: size
132
142
  }), hasClearButton && value && ___EmotionJSX(ClearButton, {
133
- onClick: onClear
143
+ onClick: onClear,
144
+ size: size
134
145
  })), errorMessage && ___EmotionJSX(Box, {
135
146
  marginTop: "var(--grn-form-control-label-gap)"
136
147
  }, ___EmotionJSX(Text, {
@@ -152,5 +163,6 @@ TextInput.propTypes = {
152
163
  type: types.textInput,
153
164
  hint: types.hint,
154
165
  backgroundColor: types.color,
155
- onClear: PropTypes.func
166
+ onClear: PropTypes.func,
167
+ size: PropTypes.oneOf(['m', 'l'])
156
168
  };
@@ -1,5 +1,5 @@
1
1
  import _styled from "@emotion/styled/base";
2
- const _excluded = ["paddingLeft", "paddingRight", "hasError", "isReadOnly", "isDisabled", "backgroundColor"],
2
+ const _excluded = ["paddingLeft", "paddingRight", "hasError", "isReadOnly", "isDisabled", "backgroundColor", "size"],
3
3
  _excluded2 = ["children"],
4
4
  _excluded3 = ["children"],
5
5
  _excluded4 = ["onClick", "tag"];
@@ -50,22 +50,30 @@ const InputFieldRoot = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "p
50
50
  paddingRight
51
51
  } = _ref3;
52
52
  return "0 ".concat(getSpace(paddingRight), " 0 ").concat(getSpace(paddingLeft));
53
- }, ";height:var(--grn-textbox-height-m);" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlFbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCwgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgSWNvbkNyb3NzIH0gZnJvbSAnLi4vaWNvbnMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbi8vIGZpeCBmb3Igc2FmYXJpIHYxNiwgaW5jb3JyZWN0IGNvbG9yIHdoZW4gZGlzYWJsZWRcbmNvbnN0IHNhZmFyaTE2Rml4ID0gYFxuICAmOm5vdCg6cGxhY2Vob2xkZXItc2hvd24pIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogJHtnZXRDb2xvcignY29udGVudCcpfTtcbiAgfVxuICAmOnBsYWNlaG9sZGVyLXNob3duIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWdybi1maWVsZC1iYWNrZ3JvdW5kLWRpc2FibGVkKTtcbiAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWRpc2FibGVkKTtcbiAgJHtzYWZhcmkxNkZpeH07XG5gO1xuXG5leHBvcnQgY29uc3QgZmllbGRQbGFjZWhvbGRlclN0eWxlcyA9IGBcbiAgLyogdGhlc2Ugc2VsZWN0b3JzIGFyZSBuZWVkZWQgdG8gZm9yY2UgdGhlIGNvbG9yICovXG4gICY6bm90KDpkaXNhYmxlZCwgOnJlYWQtb25seSk6OnBsYWNlaG9sZGVyLFxuICAmOmRpc2FibGVkOjpwbGFjZWhvbGRlcixcbiAgJjpyZWFkLW9ubHk6OnBsYWNlaG9sZGVyIHtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciB9KSA9PiBgXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICB0cmFuc2l0aW9uLXByb3BlcnR5OiBib3JkZXItY29sb3I7XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygncycpfTtcblxuICBvdXRsaW5lOiBub25lO1xuICBib3JkZXI6IHZhcigtLWdybi1ib3JkZXItc2l6ZSkgc29saWQ7XG4gIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcihoYXNFcnJvciA/ICdkYW5nZXInIDogJ3ZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3IpJyl9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKGJhY2tncm91bmRDb2xvciA/IGJhY2tncm91bmRDb2xvciA6ICd0cmFuc3BhcmVudCcpfTtcbiAgJHtmaWVsZFBsYWNlaG9sZGVyU3R5bGVzfTtcblxuICAmOmRpc2FibGVkLFxuICAmOnJlYWQtb25seSB7XG4gICAgJHtmaWVsZERpc2FibGVkU3R5bGVzfVxuICB9XG5cbiAgJHtcbiAgICAhaGFzRXJyb3IgJiZcbiAgICBgXG4gICAgJjpub3QoOmRpc2FibGVkLCA6cmVhZC1vbmx5KSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWhvdmVyKTtcbiAgICAgIH1cblxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgICAgIGJvcmRlci1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLWJvcmRlci1jb2xvci1mb2N1cyk7XG4gICAgICB9XG4gICAgfVxuICBgXG4gIH1cbmA7XG5cbmNvbnN0IElucHV0RmllbGRSb290ID0gc3R5bGVkLmlucHV0YFxuICAkeyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+XG4gICAgYDAgJHtnZXRTcGFjZShwYWRkaW5nUmlnaHQpfSAwICR7Z2V0U3BhY2UocGFkZGluZ0xlZnQpfWB9O1xuICBoZWlnaHQ6IHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dEZpZWxkID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHBhZGRpbmdMZWZ0ID0gJ3ZhcigtLWdybi1maWVsZC1wYWRkaW5nWCknLFxuICAgICAgcGFkZGluZ1JpZ2h0ID0gJ3ZhcigtLWdybi1maWVsZC1wYWRkaW5nWCknLFxuICAgICAgaGFzRXJyb3IsXG4gICAgICBpc1JlYWRPbmx5LFxuICAgICAgaXNEaXNhYmxlZCxcbiAgICAgIGJhY2tncm91bmRDb2xvcixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4gKFxuICAgIDxJbnB1dEZpZWxkUm9vdFxuICAgICAgcGFkZGluZ0xlZnQ9e3BhZGRpbmdMZWZ0fVxuICAgICAgcGFkZGluZ1JpZ2h0PXtwYWRkaW5nUmlnaHR9XG4gICAgICByZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgIGRpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApLFxuKTtcblxuSW5wdXRGaWVsZC5wcm9wVHlwZXMgPSB7XG4gIHBhZGRpbmdMZWZ0OiB0eXBlcy5zcGFjZSxcbiAgcGFkZGluZ1JpZ2h0OiB0eXBlcy5zcGFjZSxcbiAgaGFzRXJyb3I6IFByb3BUeXBlcy5ib29sLFxuICBpc1JlYWRPbmx5OiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGJhY2tncm91bmRDb2xvcjogdHlwZXMuY29sb3IsXG59O1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5GaWVsZExhYmVsLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcblxuRmllbGRIaW50LnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkQ2xlYXJCdXR0b24gPSAoeyBvbkNsaWNrLCB0YWcgPSAnYnV0dG9uJywgLi4ucHJvcHMgfSkgPT4gKFxuICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsaWNrfSB0YWc9e3RhZ30gey4uLnByb3BzfSAvPlxuKTtcblxuRmllbGRDbGVhckJ1dHRvbi5wcm9wVHlwZXMgPSB7XG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxuICB0YWc6IHR5cGVzLmJ1dHRvblRhZyxcbn07XG4iXX0= */"));
53
+ }, ";height:", _ref4 => {
54
+ let {
55
+ size
56
+ } = _ref4;
57
+ return "var(--grn-textbox-height-".concat(size, ")");
58
+ }, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlFbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCwgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgSWNvbkNyb3NzIH0gZnJvbSAnLi4vaWNvbnMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbi8vIGZpeCBmb3Igc2FmYXJpIHYxNiwgaW5jb3JyZWN0IGNvbG9yIHdoZW4gZGlzYWJsZWRcbmNvbnN0IHNhZmFyaTE2Rml4ID0gYFxuICAmOm5vdCg6cGxhY2Vob2xkZXItc2hvd24pIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogJHtnZXRDb2xvcignY29udGVudCcpfTtcbiAgfVxuICAmOnBsYWNlaG9sZGVyLXNob3duIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWdybi1maWVsZC1iYWNrZ3JvdW5kLWRpc2FibGVkKTtcbiAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWRpc2FibGVkKTtcbiAgJHtzYWZhcmkxNkZpeH07XG5gO1xuXG5leHBvcnQgY29uc3QgZmllbGRQbGFjZWhvbGRlclN0eWxlcyA9IGBcbiAgLyogdGhlc2Ugc2VsZWN0b3JzIGFyZSBuZWVkZWQgdG8gZm9yY2UgdGhlIGNvbG9yICovXG4gICY6bm90KDpkaXNhYmxlZCwgOnJlYWQtb25seSk6OnBsYWNlaG9sZGVyLFxuICAmOmRpc2FibGVkOjpwbGFjZWhvbGRlcixcbiAgJjpyZWFkLW9ubHk6OnBsYWNlaG9sZGVyIHtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciB9KSA9PiBgXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICB0cmFuc2l0aW9uLXByb3BlcnR5OiBib3JkZXItY29sb3I7XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygncycpfTtcblxuICBvdXRsaW5lOiBub25lO1xuICBib3JkZXI6IHZhcigtLWdybi1ib3JkZXItc2l6ZSkgc29saWQ7XG4gIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcihoYXNFcnJvciA/ICdkYW5nZXInIDogJ3ZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3IpJyl9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKGJhY2tncm91bmRDb2xvciA/IGJhY2tncm91bmRDb2xvciA6ICd0cmFuc3BhcmVudCcpfTtcbiAgJHtmaWVsZFBsYWNlaG9sZGVyU3R5bGVzfTtcblxuICAmOmRpc2FibGVkLFxuICAmOnJlYWQtb25seSB7XG4gICAgJHtmaWVsZERpc2FibGVkU3R5bGVzfVxuICB9XG5cbiAgJHtcbiAgICAhaGFzRXJyb3IgJiZcbiAgICBgXG4gICAgJjpub3QoOmRpc2FibGVkLCA6cmVhZC1vbmx5KSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWhvdmVyKTtcbiAgICAgIH1cblxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgICAgIGJvcmRlci1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLWJvcmRlci1jb2xvci1mb2N1cyk7XG4gICAgICB9XG4gICAgfVxuICBgXG4gIH1cbmA7XG5cbmNvbnN0IElucHV0RmllbGRSb290ID0gc3R5bGVkLmlucHV0YFxuICAkeyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+XG4gICAgYDAgJHtnZXRTcGFjZShwYWRkaW5nUmlnaHQpfSAwICR7Z2V0U3BhY2UocGFkZGluZ0xlZnQpfWB9O1xuICBoZWlnaHQ6ICR7KHsgc2l6ZSB9KSA9PiBgdmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LSR7c2l6ZX0pYH07XG5gO1xuXG5leHBvcnQgY29uc3QgSW5wdXRGaWVsZCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBwYWRkaW5nTGVmdCxcbiAgICAgIHBhZGRpbmdSaWdodCxcbiAgICAgIGhhc0Vycm9yLFxuICAgICAgaXNSZWFkT25seSxcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3IsXG4gICAgICBzaXplID0gJ20nLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgcGFkZGluZ1ggPSBgdmFyKC0tZ3JuLWZpZWxkLXBhZGRpbmdYLSR7c2l6ZX0pYDtcbiAgICByZXR1cm4gKFxuICAgICAgPElucHV0RmllbGRSb290XG4gICAgICAgIHBhZGRpbmdMZWZ0PXtwYWRkaW5nTGVmdCB8fCBwYWRkaW5nWH1cbiAgICAgICAgcGFkZGluZ1JpZ2h0PXtwYWRkaW5nUmlnaHQgfHwgcGFkZGluZ1h9XG4gICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgIHJlYWRPbmx5PXtpc1JlYWRPbmx5fVxuICAgICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgIC8+XG4gICAgKTtcbiAgfSxcbik7XG5cbklucHV0RmllbGQucHJvcFR5cGVzID0ge1xuICBwYWRkaW5nTGVmdDogdHlwZXMuc3BhY2UsXG4gIHBhZGRpbmdSaWdodDogdHlwZXMuc3BhY2UsXG4gIGhhc0Vycm9yOiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNSZWFkT25seTogUHJvcFR5cGVzLmJvb2wsXG4gIGlzRGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICBiYWNrZ3JvdW5kQ29sb3I6IHR5cGVzLmNvbG9yLFxuICBzaXplOiBQcm9wVHlwZXMub25lT2YoWydtJywgJ2wnXSksXG59O1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5GaWVsZExhYmVsLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcblxuRmllbGRIaW50LnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkQ2xlYXJCdXR0b24gPSAoeyBvbkNsaWNrLCB0YWcgPSAnYnV0dG9uJywgLi4ucHJvcHMgfSkgPT4gKFxuICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsaWNrfSB0YWc9e3RhZ30gey4uLnByb3BzfSAvPlxuKTtcblxuRmllbGRDbGVhckJ1dHRvbi5wcm9wVHlwZXMgPSB7XG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxuICB0YWc6IHR5cGVzLmJ1dHRvblRhZyxcbn07XG4iXX0= */"));
54
59
 
55
- export const InputField = /*#__PURE__*/forwardRef((_ref4, ref) => {
60
+ export const InputField = /*#__PURE__*/forwardRef((_ref5, ref) => {
56
61
  let {
57
- paddingLeft = 'var(--grn-field-paddingX)',
58
- paddingRight = 'var(--grn-field-paddingX)',
62
+ paddingLeft,
63
+ paddingRight,
59
64
  hasError,
60
65
  isReadOnly,
61
66
  isDisabled,
62
- backgroundColor
63
- } = _ref4,
64
- props = _objectWithoutProperties(_ref4, _excluded);
67
+ backgroundColor,
68
+ size = 'm'
69
+ } = _ref5,
70
+ props = _objectWithoutProperties(_ref5, _excluded);
65
71
 
72
+ const paddingX = "var(--grn-field-paddingX-".concat(size, ")");
66
73
  return ___EmotionJSX(InputFieldRoot, _extends({
67
- paddingLeft: paddingLeft,
68
- paddingRight: paddingRight,
74
+ paddingLeft: paddingLeft || paddingX,
75
+ paddingRight: paddingRight || paddingX,
76
+ size: size,
69
77
  readOnly: isReadOnly,
70
78
  disabled: isDisabled,
71
79
  ref: ref,
@@ -79,7 +87,8 @@ InputField.propTypes = {
79
87
  hasError: PropTypes.bool,
80
88
  isReadOnly: PropTypes.bool,
81
89
  isDisabled: PropTypes.bool,
82
- backgroundColor: types.color
90
+ backgroundColor: types.color,
91
+ size: PropTypes.oneOf(['m', 'l'])
83
92
  };
84
93
 
85
94
  const FieldLabelRoot = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "production" ? {
@@ -87,13 +96,13 @@ const FieldLabelRoot = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "p
87
96
  } : {
88
97
  target: "e1swxi6p0",
89
98
  label: "FieldLabelRoot"
90
- })("display:block;font-weight:", getWeight('medium'), ";transition:", getTransition('fast'), ";margin:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1IbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCwgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgSWNvbkNyb3NzIH0gZnJvbSAnLi4vaWNvbnMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbi8vIGZpeCBmb3Igc2FmYXJpIHYxNiwgaW5jb3JyZWN0IGNvbG9yIHdoZW4gZGlzYWJsZWRcbmNvbnN0IHNhZmFyaTE2Rml4ID0gYFxuICAmOm5vdCg6cGxhY2Vob2xkZXItc2hvd24pIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogJHtnZXRDb2xvcignY29udGVudCcpfTtcbiAgfVxuICAmOnBsYWNlaG9sZGVyLXNob3duIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWdybi1maWVsZC1iYWNrZ3JvdW5kLWRpc2FibGVkKTtcbiAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWRpc2FibGVkKTtcbiAgJHtzYWZhcmkxNkZpeH07XG5gO1xuXG5leHBvcnQgY29uc3QgZmllbGRQbGFjZWhvbGRlclN0eWxlcyA9IGBcbiAgLyogdGhlc2Ugc2VsZWN0b3JzIGFyZSBuZWVkZWQgdG8gZm9yY2UgdGhlIGNvbG9yICovXG4gICY6bm90KDpkaXNhYmxlZCwgOnJlYWQtb25seSk6OnBsYWNlaG9sZGVyLFxuICAmOmRpc2FibGVkOjpwbGFjZWhvbGRlcixcbiAgJjpyZWFkLW9ubHk6OnBsYWNlaG9sZGVyIHtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciB9KSA9PiBgXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICB0cmFuc2l0aW9uLXByb3BlcnR5OiBib3JkZXItY29sb3I7XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygncycpfTtcblxuICBvdXRsaW5lOiBub25lO1xuICBib3JkZXI6IHZhcigtLWdybi1ib3JkZXItc2l6ZSkgc29saWQ7XG4gIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcihoYXNFcnJvciA/ICdkYW5nZXInIDogJ3ZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3IpJyl9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKGJhY2tncm91bmRDb2xvciA/IGJhY2tncm91bmRDb2xvciA6ICd0cmFuc3BhcmVudCcpfTtcbiAgJHtmaWVsZFBsYWNlaG9sZGVyU3R5bGVzfTtcblxuICAmOmRpc2FibGVkLFxuICAmOnJlYWQtb25seSB7XG4gICAgJHtmaWVsZERpc2FibGVkU3R5bGVzfVxuICB9XG5cbiAgJHtcbiAgICAhaGFzRXJyb3IgJiZcbiAgICBgXG4gICAgJjpub3QoOmRpc2FibGVkLCA6cmVhZC1vbmx5KSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWhvdmVyKTtcbiAgICAgIH1cblxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgICAgIGJvcmRlci1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLWJvcmRlci1jb2xvci1mb2N1cyk7XG4gICAgICB9XG4gICAgfVxuICBgXG4gIH1cbmA7XG5cbmNvbnN0IElucHV0RmllbGRSb290ID0gc3R5bGVkLmlucHV0YFxuICAkeyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+XG4gICAgYDAgJHtnZXRTcGFjZShwYWRkaW5nUmlnaHQpfSAwICR7Z2V0U3BhY2UocGFkZGluZ0xlZnQpfWB9O1xuICBoZWlnaHQ6IHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKTtcbmA7XG5cbmV4cG9ydCBjb25zdCBJbnB1dEZpZWxkID0gZm9yd2FyZFJlZihcbiAgKFxuICAgIHtcbiAgICAgIHBhZGRpbmdMZWZ0ID0gJ3ZhcigtLWdybi1maWVsZC1wYWRkaW5nWCknLFxuICAgICAgcGFkZGluZ1JpZ2h0ID0gJ3ZhcigtLWdybi1maWVsZC1wYWRkaW5nWCknLFxuICAgICAgaGFzRXJyb3IsXG4gICAgICBpc1JlYWRPbmx5LFxuICAgICAgaXNEaXNhYmxlZCxcbiAgICAgIGJhY2tncm91bmRDb2xvcixcbiAgICAgIC4uLnByb3BzXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4gKFxuICAgIDxJbnB1dEZpZWxkUm9vdFxuICAgICAgcGFkZGluZ0xlZnQ9e3BhZGRpbmdMZWZ0fVxuICAgICAgcGFkZGluZ1JpZ2h0PXtwYWRkaW5nUmlnaHR9XG4gICAgICByZWFkT25seT17aXNSZWFkT25seX1cbiAgICAgIGRpc2FibGVkPXtpc0Rpc2FibGVkfVxuICAgICAgcmVmPXtyZWZ9XG4gICAgICBoYXNFcnJvcj17aGFzRXJyb3J9XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9e2JhY2tncm91bmRDb2xvcn1cbiAgICAgIHsuLi5wcm9wc31cbiAgICAvPlxuICApLFxuKTtcblxuSW5wdXRGaWVsZC5wcm9wVHlwZXMgPSB7XG4gIHBhZGRpbmdMZWZ0OiB0eXBlcy5zcGFjZSxcbiAgcGFkZGluZ1JpZ2h0OiB0eXBlcy5zcGFjZSxcbiAgaGFzRXJyb3I6IFByb3BUeXBlcy5ib29sLFxuICBpc1JlYWRPbmx5OiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNEaXNhYmxlZDogUHJvcFR5cGVzLmJvb2wsXG4gIGJhY2tncm91bmRDb2xvcjogdHlwZXMuY29sb3IsXG59O1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5GaWVsZExhYmVsLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcblxuRmllbGRIaW50LnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkQ2xlYXJCdXR0b24gPSAoeyBvbkNsaWNrLCB0YWcgPSAnYnV0dG9uJywgLi4ucHJvcHMgfSkgPT4gKFxuICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsaWNrfSB0YWc9e3RhZ30gey4uLnByb3BzfSAvPlxuKTtcblxuRmllbGRDbGVhckJ1dHRvbi5wcm9wVHlwZXMgPSB7XG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxuICB0YWc6IHR5cGVzLmJ1dHRvblRhZyxcbn07XG4iXX0= */"));
99
+ })("display:block;font-weight:", getWeight('medium'), ";transition:", getTransition('fast'), ";margin:unset;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mb3VuZGF0aW9uYWwvZmllbGQuanN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlIbUMiLCJmaWxlIjoiLi4vLi4vc3JjL2ZvdW5kYXRpb25hbC9maWVsZC5qc3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBmb3J3YXJkUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgVGV4dCwgSWNvbkJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgSWNvbkNyb3NzIH0gZnJvbSAnLi4vaWNvbnMnO1xuaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cywgZ2V0U3BhY2UsIGdldFRyYW5zaXRpb24sIGdldFdlaWdodCB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuL3N0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyB0eXBlcyB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5cbi8vIGZpeCBmb3Igc2FmYXJpIHYxNiwgaW5jb3JyZWN0IGNvbG9yIHdoZW4gZGlzYWJsZWRcbmNvbnN0IHNhZmFyaTE2Rml4ID0gYFxuICAmOm5vdCg6cGxhY2Vob2xkZXItc2hvd24pIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogJHtnZXRDb2xvcignY29udGVudCcpfTtcbiAgfVxuICAmOnBsYWNlaG9sZGVyLXNob3duIHtcbiAgICAtd2Via2l0LXRleHQtZmlsbC1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuICBvcGFjaXR5OiAxO1xuYDtcblxuZXhwb3J0IGNvbnN0IGZpZWxkRGlzYWJsZWRTdHlsZXMgPSBgXG4gIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWdybi1maWVsZC1iYWNrZ3JvdW5kLWRpc2FibGVkKTtcbiAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWRpc2FibGVkKTtcbiAgJHtzYWZhcmkxNkZpeH07XG5gO1xuXG5leHBvcnQgY29uc3QgZmllbGRQbGFjZWhvbGRlclN0eWxlcyA9IGBcbiAgLyogdGhlc2Ugc2VsZWN0b3JzIGFyZSBuZWVkZWQgdG8gZm9yY2UgdGhlIGNvbG9yICovXG4gICY6bm90KDpkaXNhYmxlZCwgOnJlYWQtb25seSk6OnBsYWNlaG9sZGVyLFxuICAmOmRpc2FibGVkOjpwbGFjZWhvbGRlcixcbiAgJjpyZWFkLW9ubHk6OnBsYWNlaG9sZGVyIHtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWZpZWxkLXBsYWNlaG9sZGVyLWNvbG9yKTtcbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGdldEZpZWxkU3R5bGVzID0gKHsgaGFzRXJyb3IsIGJhY2tncm91bmRDb2xvciB9KSA9PiBgXG4gICR7c3R5bGVzLnRyYW5zaXRpb25zfTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQ6IGluaGVyaXQ7XG4gIGNvbG9yOiBpbmhlcml0O1xuICB0cmFuc2l0aW9uLXByb3BlcnR5OiBib3JkZXItY29sb3I7XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke2dldFJhZGl1cygncycpfTtcblxuICBvdXRsaW5lOiBub25lO1xuICBib3JkZXI6IHZhcigtLWdybi1ib3JkZXItc2l6ZSkgc29saWQ7XG4gIGJvcmRlci1jb2xvcjogJHtnZXRDb2xvcihoYXNFcnJvciA/ICdkYW5nZXInIDogJ3ZhcigtLWdybi1maWVsZC1ib3JkZXItY29sb3IpJyl9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKGJhY2tncm91bmRDb2xvciA/IGJhY2tncm91bmRDb2xvciA6ICd0cmFuc3BhcmVudCcpfTtcbiAgJHtmaWVsZFBsYWNlaG9sZGVyU3R5bGVzfTtcblxuICAmOmRpc2FibGVkLFxuICAmOnJlYWQtb25seSB7XG4gICAgJHtmaWVsZERpc2FibGVkU3R5bGVzfVxuICB9XG5cbiAgJHtcbiAgICAhaGFzRXJyb3IgJiZcbiAgICBgXG4gICAgJjpub3QoOmRpc2FibGVkLCA6cmVhZC1vbmx5KSB7XG4gICAgICAmOmhvdmVyIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiB2YXIoLS1ncm4tZmllbGQtYm9yZGVyLWNvbG9yLWhvdmVyKTtcbiAgICAgIH1cblxuICAgICAgJjpmb2N1cyB7XG4gICAgICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgICAgIGJvcmRlci1jb2xvcjogdmFyKC0tZ3JuLWZpZWxkLWJvcmRlci1jb2xvci1mb2N1cyk7XG4gICAgICB9XG4gICAgfVxuICBgXG4gIH1cbmA7XG5cbmNvbnN0IElucHV0RmllbGRSb290ID0gc3R5bGVkLmlucHV0YFxuICAkeyh7IGhhc0Vycm9yLCBiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gZ2V0RmllbGRTdHlsZXMoeyBoYXNFcnJvciwgYmFja2dyb3VuZENvbG9yIH0pfTtcbiAgcGFkZGluZzogJHsoeyBwYWRkaW5nTGVmdCwgcGFkZGluZ1JpZ2h0IH0pID0+XG4gICAgYDAgJHtnZXRTcGFjZShwYWRkaW5nUmlnaHQpfSAwICR7Z2V0U3BhY2UocGFkZGluZ0xlZnQpfWB9O1xuICBoZWlnaHQ6ICR7KHsgc2l6ZSB9KSA9PiBgdmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LSR7c2l6ZX0pYH07XG5gO1xuXG5leHBvcnQgY29uc3QgSW5wdXRGaWVsZCA9IGZvcndhcmRSZWYoXG4gIChcbiAgICB7XG4gICAgICBwYWRkaW5nTGVmdCxcbiAgICAgIHBhZGRpbmdSaWdodCxcbiAgICAgIGhhc0Vycm9yLFxuICAgICAgaXNSZWFkT25seSxcbiAgICAgIGlzRGlzYWJsZWQsXG4gICAgICBiYWNrZ3JvdW5kQ29sb3IsXG4gICAgICBzaXplID0gJ20nLFxuICAgICAgLi4ucHJvcHNcbiAgICB9LFxuICAgIHJlZixcbiAgKSA9PiB7XG4gICAgY29uc3QgcGFkZGluZ1ggPSBgdmFyKC0tZ3JuLWZpZWxkLXBhZGRpbmdYLSR7c2l6ZX0pYDtcbiAgICByZXR1cm4gKFxuICAgICAgPElucHV0RmllbGRSb290XG4gICAgICAgIHBhZGRpbmdMZWZ0PXtwYWRkaW5nTGVmdCB8fCBwYWRkaW5nWH1cbiAgICAgICAgcGFkZGluZ1JpZ2h0PXtwYWRkaW5nUmlnaHQgfHwgcGFkZGluZ1h9XG4gICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgIHJlYWRPbmx5PXtpc1JlYWRPbmx5fVxuICAgICAgICBkaXNhYmxlZD17aXNEaXNhYmxlZH1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGhhc0Vycm9yPXtoYXNFcnJvcn1cbiAgICAgICAgYmFja2dyb3VuZENvbG9yPXtiYWNrZ3JvdW5kQ29sb3J9XG4gICAgICAgIHsuLi5wcm9wc31cbiAgICAgIC8+XG4gICAgKTtcbiAgfSxcbik7XG5cbklucHV0RmllbGQucHJvcFR5cGVzID0ge1xuICBwYWRkaW5nTGVmdDogdHlwZXMuc3BhY2UsXG4gIHBhZGRpbmdSaWdodDogdHlwZXMuc3BhY2UsXG4gIGhhc0Vycm9yOiBQcm9wVHlwZXMuYm9vbCxcbiAgaXNSZWFkT25seTogUHJvcFR5cGVzLmJvb2wsXG4gIGlzRGlzYWJsZWQ6IFByb3BUeXBlcy5ib29sLFxuICBiYWNrZ3JvdW5kQ29sb3I6IHR5cGVzLmNvbG9yLFxuICBzaXplOiBQcm9wVHlwZXMub25lT2YoWydtJywgJ2wnXSksXG59O1xuXG5jb25zdCBGaWVsZExhYmVsUm9vdCA9IHN0eWxlZC5sYWJlbGBcbiAgZGlzcGxheTogYmxvY2s7XG4gIGZvbnQtd2VpZ2h0OiAke2dldFdlaWdodCgnbWVkaXVtJyl9O1xuICB0cmFuc2l0aW9uOiAke2dldFRyYW5zaXRpb24oJ2Zhc3QnKX07XG5cbiAgLyogVE9ETzogcmVtb3ZlIGFmdGVyIGRlbGV0aW5nIEJvb3RzdHJhcCAqL1xuICBtYXJnaW46IHVuc2V0O1xuYDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkTGFiZWwgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPEZpZWxkTGFiZWxSb290IHJlZj17cmVmfSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9GaWVsZExhYmVsUm9vdD5cbikpO1xuXG5GaWVsZExhYmVsLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkSGludCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8VGV4dCBjb2xvcj1cImNvbnRlbnQyXCIgcmVmPXtyZWZ9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1RleHQ+XG4pKTtcblxuRmllbGRIaW50LnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxufTtcblxuZXhwb3J0IGNvbnN0IEZpZWxkQ2xlYXJCdXR0b24gPSAoeyBvbkNsaWNrLCB0YWcgPSAnYnV0dG9uJywgLi4ucHJvcHMgfSkgPT4gKFxuICA8SWNvbkJ1dHRvbiBpY29uPXs8SWNvbkNyb3NzIC8+fSBvbkNsaWNrPXtvbkNsaWNrfSB0YWc9e3RhZ30gey4uLnByb3BzfSAvPlxuKTtcblxuRmllbGRDbGVhckJ1dHRvbi5wcm9wVHlwZXMgPSB7XG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxuICB0YWc6IHR5cGVzLmJ1dHRvblRhZyxcbn07XG4iXX0= */"));
91
100
 
92
- export const FieldLabel = /*#__PURE__*/forwardRef((_ref5, ref) => {
101
+ export const FieldLabel = /*#__PURE__*/forwardRef((_ref6, ref) => {
93
102
  let {
94
103
  children
95
- } = _ref5,
96
- props = _objectWithoutProperties(_ref5, _excluded2);
104
+ } = _ref6,
105
+ props = _objectWithoutProperties(_ref6, _excluded2);
97
106
 
98
107
  return ___EmotionJSX(FieldLabelRoot, _extends({
99
108
  ref: ref
@@ -102,11 +111,11 @@ export const FieldLabel = /*#__PURE__*/forwardRef((_ref5, ref) => {
102
111
  FieldLabel.propTypes = {
103
112
  children: PropTypes.node
104
113
  };
105
- export const FieldHint = /*#__PURE__*/forwardRef((_ref6, ref) => {
114
+ export const FieldHint = /*#__PURE__*/forwardRef((_ref7, ref) => {
106
115
  let {
107
116
  children
108
- } = _ref6,
109
- props = _objectWithoutProperties(_ref6, _excluded3);
117
+ } = _ref7,
118
+ props = _objectWithoutProperties(_ref7, _excluded3);
110
119
 
111
120
  return ___EmotionJSX(Text, _extends({
112
121
  color: "content2",
@@ -116,12 +125,12 @@ export const FieldHint = /*#__PURE__*/forwardRef((_ref6, ref) => {
116
125
  FieldHint.propTypes = {
117
126
  children: PropTypes.node
118
127
  };
119
- export const FieldClearButton = _ref7 => {
128
+ export const FieldClearButton = _ref8 => {
120
129
  let {
121
130
  onClick,
122
131
  tag = 'button'
123
- } = _ref7,
124
- props = _objectWithoutProperties(_ref7, _excluded4);
132
+ } = _ref8,
133
+ props = _objectWithoutProperties(_ref8, _excluded4);
125
134
 
126
135
  return ___EmotionJSX(IconButton, _extends({
127
136
  icon: ___EmotionJSX(IconCross, null),
@@ -2,10 +2,10 @@ const legacyVariables = "\n :root {\n --grn-textbox-textSize-s: var(--grn-te
2
2
  export const borderVariables = "\n :root {\n --grn-border-size: 1px;\n }\n";
3
3
  const capValue = "\n :root {\n @supports not (font-size: 1cap) { --grn-cap-value: 0.74em }\n @supports (font-size: 1cap) { --grn-cap-value: 1cap }\n }\n";
4
4
  export const capVariables = "\n :root {\n --grn-cap: var(--grn-cap-value);\n }\n";
5
- export const fieldVariables = "\n :root, [data-theme] {\n --grn-field-paddingX: var(--grn-space-s2);\n --grn-field-border-color: var(--grn-color-fade3);\n --grn-field-border-color-hover: var(--grn-color-fade6);\n --grn-field-border-color-focus: var(--grn-color-shade9);\n --grn-field-border-color-disabled: var(--grn-color-shade5);\n --grn-field-background-disabled: var(--grn-color-shade2);\n --grn-field-placeholder-color: var(--grn-color-shade7);\n }\n";
5
+ export const fieldVariables = "\n :root, [data-theme] {\n --grn-field-paddingX: var(--grn-space-s2);\n --grn-field-paddingX-m: var(--grn-space-s2);\n --grn-field-paddingX-l: var(--grn-textbox-paddingX-l);\n\n --grn-field-border-color: var(--grn-color-fade3);\n --grn-field-border-color-hover: var(--grn-color-fade6);\n --grn-field-border-color-focus: var(--grn-color-shade9);\n --grn-field-border-color-disabled: var(--grn-color-shade5);\n --grn-field-background-disabled: var(--grn-color-shade2);\n --grn-field-placeholder-color: var(--grn-color-shade7);\n }\n";
6
6
  export const componentVariables = "\n :root, [data-theme] {\n --grn-clearbutton-danger-background-hover: hsl(var(--redHS) var(--redL) / 12%);\n --grn-clearbutton-danger-background-active: hsl(var(--redHS) var(--redL) / 19%);\n --grn-icon-danger-color: hsl(var(--redHS) var(--redL) / 70%);\n }\n";
7
- const experiments = "\n [data-experiment-compact-textbox=\"true\"] {\n --grn-textBoxHeight: 36px;\n\n --grn-textbox-height-m: 36px;\n --grn-textbox-paddingX-m: var(--grn-space-s2);\n }\n :root [data-experiment-lighter-fields='true'],\n [data-theme][data-experiment-lighter-fields='true'] {\n --grn-field-border-color: var(--grn-color-fade2);\n }\n\n [data-experiment-match-button-and-field-padding=\"true\"] {\n --grn-field-paddingX: 14px;\n --grn-textbox-paddingX-m: 14px;\n }\n";
8
- export const textboxVariables = "\n :root {\n --grn-textbox-height-s: 28px;\n --grn-textbox-paddingX-s: var(--grn-space-s);\n --grn-textbox-radius-s: var(--grn-radius-xs);\n --grn-textbox-text-s: var(--grn-text-s);\n\n --grn-textbox-height-m: 40px;\n --grn-textbox-paddingX-m: var(--grn-space-m);\n --grn-textbox-radius-m: var(--grn-radius-s);\n --grn-textbox-text-m: var(--grn-text-m);\n }\n";
7
+ const experiments = "\n [data-experiment-compact-textbox=\"true\"] {\n --grn-textBoxHeight: 36px;\n\n --grn-textbox-height-m: 36px;\n --grn-textbox-paddingX-m: var(--grn-space-s2);\n }\n :root [data-experiment-lighter-fields='true'],\n [data-theme][data-experiment-lighter-fields='true'] {\n --grn-field-border-color: var(--grn-color-fade2);\n }\n\n [data-experiment-match-button-and-field-padding=\"true\"] {\n --grn-field-paddingX: 14px;\n --grn-field-paddingX-m: 14px;\n --grn-textbox-paddingX-m: 14px;\n }\n";
8
+ export const textboxVariables = "\n :root {\n --grn-textbox-height-s: 28px;\n --grn-textbox-paddingX-s: var(--grn-space-s);\n --grn-textbox-radius-s: var(--grn-radius-xs);\n --grn-textbox-text-s: var(--grn-text-s);\n\n --grn-textbox-height-m: 40px;\n --grn-textbox-paddingX-m: var(--grn-space-m);\n --grn-textbox-radius-m: var(--grn-radius-s);\n --grn-textbox-text-m: var(--grn-text-m);\n\n --grn-textbox-height-l: 48px;\n --grn-textbox-paddingX-l: 18px;\n --grn-textbox-radius-l: var(--grn-radius-m);\n --grn-textbox-text-l: var(--grn-text-m);\n }\n";
9
9
  export const clearbuttonVariables = "\n :root {\n --grn-clearbutton-height: 36px;\n }\n";
10
10
  export const formVariables = "\n :root {\n --grn-form-title-content-gap: var(--grn-space-l);\n --grn-form-contents-gap: var(--grn-space-m);\n --grn-form-content-actions-gap: var(--grn-space-xl);\n --grn-form-control-label-gap: var(--grn-space-s);\n }\n";
11
11
  export const transitionVariables = "\n :root {\n --grn-transition-leave: var(--grn-transition-slow);\n --grn-transition-hover: var(--grn-transition-fast);\n --grn-transition-active: var(--grn-transition-xxFast);\n }\n";
@@ -6,7 +6,7 @@ export interface LinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement>
6
6
  target?: string;
7
7
  variant?: 'neutral' | 'subtle';
8
8
  tag?: 'a' | 'button' | 'span';
9
- onClick?: () => void;
9
+ onClick?: (e: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement | HTMLSpanElement>) => void;
10
10
  }
11
11
 
12
12
  export const Link: FC<LinkProps>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flodesk/grain",
3
- "version": "11.46.1",
3
+ "version": "11.47.1",
4
4
  "description": "Flodesk design system",
5
5
  "module": "es/index.js",
6
6
  "types": "es/types/index.d.ts",