@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.
- package/es/components/autocomplete2.js +51 -33
- package/es/components/button.js +31 -13
- package/es/components/select.js +48 -31
- package/es/components/text-input.js +27 -15
- package/es/foundational/field.js +30 -21
- package/es/styles/foundational.js +3 -3
- package/es/types/components/link.d.ts +1 -1
- package/package.json +1 -1
package/es/components/select.js
CHANGED
|
@@ -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 =
|
|
49
|
+
const ClearButton = _ref4 => {
|
|
40
50
|
let {
|
|
41
51
|
onClick
|
|
42
|
-
} =
|
|
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((
|
|
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
|
-
|
|
63
|
-
|
|
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 =
|
|
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
|
-
|
|
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 =
|
|
155
|
+
const SelectMenuOption = _ref7 => {
|
|
142
156
|
let {
|
|
143
157
|
option,
|
|
144
158
|
isSelected,
|
|
145
159
|
menuItemsHaveEllipsis,
|
|
146
160
|
allowMultiple
|
|
147
|
-
} =
|
|
148
|
-
props = _objectWithoutProperties(
|
|
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),
|
|
168
|
+
}, props), _ref8 => {
|
|
155
169
|
let {
|
|
156
170
|
active
|
|
157
|
-
} =
|
|
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 =
|
|
181
|
+
const SelectInfo = _ref9 => {
|
|
168
182
|
let {
|
|
169
183
|
label,
|
|
170
184
|
hint
|
|
171
|
-
} =
|
|
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 =
|
|
193
|
+
const SelectMenu = _ref10 => {
|
|
180
194
|
let {
|
|
181
195
|
children,
|
|
182
196
|
floating,
|
|
183
197
|
hasPortal,
|
|
184
198
|
isOpen
|
|
185
|
-
} =
|
|
186
|
-
props = _objectWithoutProperties(
|
|
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 =
|
|
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
|
-
|
|
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
|
-
},
|
|
280
|
+
}, _ref12 => {
|
|
266
281
|
let {
|
|
267
282
|
open
|
|
268
|
-
} =
|
|
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,
|
|
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-
|
|
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,
|
|
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,
|
|
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 ?
|
|
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
|
};
|
package/es/foundational/field.js
CHANGED
|
@@ -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:
|
|
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((
|
|
60
|
+
export const InputField = /*#__PURE__*/forwardRef((_ref5, ref) => {
|
|
56
61
|
let {
|
|
57
|
-
paddingLeft
|
|
58
|
-
paddingRight
|
|
62
|
+
paddingLeft,
|
|
63
|
+
paddingRight,
|
|
59
64
|
hasError,
|
|
60
65
|
isReadOnly,
|
|
61
66
|
isDisabled,
|
|
62
|
-
backgroundColor
|
|
63
|
-
|
|
64
|
-
|
|
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,
|
|
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((
|
|
101
|
+
export const FieldLabel = /*#__PURE__*/forwardRef((_ref6, ref) => {
|
|
93
102
|
let {
|
|
94
103
|
children
|
|
95
|
-
} =
|
|
96
|
-
props = _objectWithoutProperties(
|
|
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((
|
|
114
|
+
export const FieldHint = /*#__PURE__*/forwardRef((_ref7, ref) => {
|
|
106
115
|
let {
|
|
107
116
|
children
|
|
108
|
-
} =
|
|
109
|
-
props = _objectWithoutProperties(
|
|
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 =
|
|
128
|
+
export const FieldClearButton = _ref8 => {
|
|
120
129
|
let {
|
|
121
130
|
onClick,
|
|
122
131
|
tag = 'button'
|
|
123
|
-
} =
|
|
124
|
-
props = _objectWithoutProperties(
|
|
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>;
|