td-stylekit 28.22.1 → 28.22.2

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/CHANGELOG.md CHANGED
@@ -1,3 +1,10 @@
1
+ ## [28.22.2](https://github.com/treasure-data/td-stylekit/compare/v28.22.1...v28.22.2) (2023-06-08)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * **CON-13112:** Fix props table disappear in Storybook issue ([#1479](https://github.com/treasure-data/td-stylekit/issues/1479)) ([8407470](https://github.com/treasure-data/td-stylekit/commit/8407470))
7
+
1
8
  ## [28.22.1](https://github.com/treasure-data/td-stylekit/compare/v28.22.0...v28.22.1) (2023-05-30)
2
9
 
3
10
 
@@ -93,7 +93,6 @@ var ActionBar = function ActionBar(props) {
93
93
  };
94
94
 
95
95
  exports.ActionBar = ActionBar;
96
- ActionBar.displayName = 'ActionBar';
97
96
  ActionBar.Button = _components.IconButton;
98
97
  ActionBar.ButtonLink = IconButtonLink;
99
98
  ActionBar.Menu = _components.ActionMenu;
@@ -437,7 +437,8 @@ var StyledButton = ( /*#__PURE__*/0, _base["default"])(UnstyledButton, process.e
437
437
  } : {
438
438
  target: "e1tp8vho0",
439
439
  label: "StyledButton"
440
- })(styles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Button/Button.tsx"],"names":[],"mappings":"AAyfqB","file":"../../../src/Button/Button.tsx","sourcesContent":["import React, {\n  Component,\n  forwardRef,\n  createRef,\n  ReactNode,\n  ComponentType,\n  SyntheticEvent,\n  KeyboardEvent\n} from 'react'\nimport color from 'color'\nimport styled from '@emotion/styled'\nimport omit from 'lodash.omit'\nimport { multiply } from '../utils'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\nimport { Spinner } from './elements'\n\nconst styles: Array<(props: any) => any> = [\n  // reset\n  ({\n    disabled,\n    theme\n  }: {\n    ignoreFocus: boolean\n    disabled: boolean\n    loading: boolean\n    theme: Theme\n  }) => ({\n    alignItems: 'center',\n    backgroundColor: 'transparent',\n    border: '1px solid transparent',\n    cursor: disabled ? 'default' : 'pointer',\n    display: 'inline-flex',\n    flexShrink: 0,\n    fontFamily: theme.fontFamily.body,\n    justifyContent: 'center',\n    margin: 0,\n    padding: 0,\n    position: 'relative',\n    textAlign: 'center',\n    textDecoration: 'none',\n    textRendering: 'optimizeLegibility',\n    touchAction: 'manipulation',\n    userSelect: 'none',\n    verticalAlign: 'middle',\n    whiteSpace: 'nowrap'\n  }),\n  // default outline\n  ({\n    theme,\n    plain,\n    icon,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    plain: boolean\n    icon: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    !plain &&\n    !icon && {\n      backgroundColor: theme.palette.neutral[0],\n      border: disabled\n        ? `1px solid ${color(theme.palette.primary[4]).alpha(0.3).string()}`\n        : `1px solid ${theme.palette.primary[4]}`,\n      borderRadius: theme.radius[4],\n      color: disabled\n        ? color(theme.palette.primary[4]).alpha(0.3).string()\n        : theme.palette.primary[4],\n      fontSize: theme.fontSize[0],\n      fontWeight: 600,\n      height: theme.space[8],\n      lineHeight: theme.lineHeight[4],\n      overflow: 'hidden',\n      padding: `0 ${theme.space[4]}`,\n      textOverflow: 'ellipsis',\n      outline: 'none',\n      textTransform: 'unset',\n      transition: 'transform 0.15s ease-in-out',\n      ':hover': !disabled &&\n        !loading && {\n          boxShadow: '0px 2px 7px rgba(0, 0, 0, 0.2)',\n          transform: 'translateY(-1px)'\n        },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: theme.palette.primary[0],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.primary[4])\n            .darken(0.1)\n            .string()}`\n        }\n    },\n\n  // primary\n  ({\n    theme,\n    primary,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    primary: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    primary && {\n      backgroundColor: disabled\n        ? color(theme.palette.primary[4]).alpha(0.3).string()\n        : theme.palette.primary[4],\n      color: theme.palette.neutral[0],\n      borderColor: 'transparent',\n      ':hover': !disabled &&\n        !loading && {\n          backgroundColor: color(theme.palette.primary[4])\n            .lighten(0.4)\n            .string(),\n          boxShadow: `0 2px 7px ${color(theme.palette.primary[4])\n            .lighten(0.4)\n            .alpha(0.35)\n            .string()}`\n        },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: theme.palette.primary[5],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.primary[5])\n            .darken(0.425)\n            .string()}`,\n          color: theme.palette.neutral[0]\n        }\n    },\n\n  // borderless\n  ({\n    theme,\n    borderless,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    borderless: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    borderless && {\n      backgroundColor: 'transparent',\n      border: 'none',\n      color: disabled\n        ? color(theme.palette.primary[4]).alpha(0.3).string()\n        : theme.palette.primary[4],\n      borderColor: 'none',\n      ':hover': !disabled &&\n        !loading && {\n          boxShadow: 'none',\n          textDecoration: 'underline',\n          transform: 'none'\n        },\n      ':active': !disabled &&\n        !loading && {\n          background: 'transparent',\n          boxShadow: 'none'\n        }\n    },\n  // borderless Alt\n  ({\n    theme,\n    borderlessAlt,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    borderlessAlt: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    borderlessAlt && {\n      background: 'transparent',\n      color: disabled\n        ? color(theme.palette.neutral[0]).alpha(0.5).string()\n        : theme.palette.neutral[0],\n      borderColor: 'none',\n      border: 'none',\n      ':hover': !disabled &&\n        !loading && {\n          boxShadow: `none`,\n          textDecoration: 'underline',\n          transform: 'none'\n        },\n      ':active': !disabled &&\n        !loading && {\n          background: 'transparent',\n          textDecoration: 'underline'\n        }\n    },\n  // icon\n  ({ theme, icon, small }: { theme: Theme; icon: boolean; small: boolean }) =>\n    icon && {\n      borderRadius: 0,\n      height: 'auto',\n      padding: 0,\n      minHeight: small\n        ? multiply(theme.space[2], 2.5)\n        : multiply(theme.space[3], 3),\n      minWidth: small\n        ? multiply(theme.space[2], 2.5)\n        : multiply(theme.space[3], 3)\n    },\n  // circle\n  ({ theme, circle }: { theme: Theme; circle: boolean }) =>\n    circle && {\n      borderRadius: '50%',\n      height: multiply(theme.space[3], 2),\n      lineHeight: theme.lineHeight[4],\n      padding: 0,\n      overflow: 'hidden',\n      width: multiply(theme.space[3], 2),\n      ':hover': {\n        transform: 'none'\n      }\n    },\n  // danger\n  ({\n    theme,\n    danger,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    danger: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    danger && {\n      backgroundColor: disabled\n        ? color(theme.palette.error[1]).alpha(0.3).string()\n        : theme.palette.error[1],\n      color: theme.palette.neutral[0],\n      border: 'none',\n      ':hover': !disabled &&\n        !loading && {\n          backgroundColor: color(theme.palette.error[1]).lighten(0.2).string(),\n          boxShadow: `0 2px 7px ${color(theme.palette.error[1])\n            .lighten(0.2)\n            .string()}`\n        },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: color(theme.palette.error[1]).darken(0.1).string(),\n          borderColor: 'transparent',\n          color: theme.palette.neutral[0],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.error[1])\n            .darken(0.3)\n            .string()}`\n        }\n    },\n  // dangerAlt\n  ({\n    theme,\n    dangerAlt,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    dangerAlt: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    dangerAlt && {\n      backgroundColor: disabled\n        ? color(theme.palette.neutral[0]).alpha(0.5).string()\n        : theme.palette.neutral[0],\n      color: theme.palette.error[1],\n      border: 'none',\n      ':hover': !disabled &&\n        !loading && { boxShadow: `0 2px 7px rgba(0, 0, 0, 0.5)` },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: 'transparent',\n          color: theme.palette.error[1],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.neutral[0])\n            .darken(0.3)\n            .string()}`\n        }\n    },\n  // loading\n  ({ theme, loading }: { theme: Theme; loading: boolean }) =>\n    loading && {\n      backgroundColor: theme.palette.neutral[3],\n      border: 'none',\n      color: theme.palette.neutral[9],\n      cursor: 'default'\n    },\n  // noFocus\n  ({ ignoreFocus }: { ignoreFocus: boolean }) =>\n    ignoreFocus && {\n      outline: 'none',\n      ':focus': {\n        outline: 'none'\n      }\n    },\n  // coloredFocus\n  ({ theme, colorFocus }: { theme: Theme; colorFocus: boolean }) =>\n    colorFocus && {\n      outline: 'none',\n      ':focus': {\n        outline: 'none',\n        color: theme.palette.primary[4]\n      }\n    },\n  getOverrides(Overridable.Button.Root)\n]\n\nexport type UnstyledButtonProps = {\n  /** Focus the button when it's rendered */\n  autofocus?: boolean\n  /** Unfocus the button when it's clicked */\n  blurOnClick?: boolean\n  /** Text Button */\n  borderless?: boolean\n  /** Text Button on non-white Background */\n  borderlessAlt?: boolean\n  children: ReactNode\n  /** Enable circle style */\n  circle?: boolean\n  className?: string\n  /** Removes outline and changes color to Primary on focus */\n  colorFocus?: boolean\n  /** Stateful component or html tag to render as (defaults to `button`) */\n  component: ComponentType<any> | string\n  /** Enable danger style */\n  danger?: boolean\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Enable dangerAlt style --- white background */\n  dangerAlt?: boolean\n  /** Enable disabled style */\n  disabled?: boolean\n  /** Title to display when button is disabled */\n  disabledTitle?: string\n  getRef?: React.RefObject<HTMLElement>\n  form?: string\n  href?: string\n  id?: string\n  /** Enable styles suitible for wrapping icons */\n  icon?: boolean\n  /** Prevent button from being focused */\n  ignoreFocus?: boolean\n  loading?: boolean\n  onClick?: (event: SyntheticEvent<HTMLButtonElement>) => void\n  onKeyPress?: (event: KeyboardEvent<HTMLButtonElement>) => void\n  onMouseDown?: (event: KeyboardEvent<HTMLButtonElement>) => void\n  /** Disable default button styles */\n  plain?: boolean\n  /** Fill button with solid color */\n  primary?: boolean\n  rel?: string\n  /** Only used with `icon`. */\n  small?: boolean\n  target?: string\n  theme?: Theme\n  /** Title to display when button is enabled */\n  title?: string\n  /** HTML button type attribute */\n  type?: React.ButtonHTMLAttributes<HTMLButtonElement>['type']\n  hasError?: boolean\n  /** Indicates whether the button should not have a special visual appearance when mouse hovers above it. */\n  hoverless?: boolean\n}\n\nexport class UnstyledButton extends Component<UnstyledButtonProps> {\n  static defaultProps = {\n    borderless: false,\n    borderlessAlt: false,\n    blurOnClick: false,\n    circle: false,\n    component: 'button',\n    danger: false,\n    dangerAlt: false,\n    'data-instrumentation': 'button',\n    disabled: false,\n    loading: false,\n    small: false,\n    primary: false,\n    hoverless: false\n  }\n\n  /**\n   * https://mathiasbynens.github.io/rel-noopener/\n   * Using target=_blank is insecure, so we add\n   * rel=noopener to reduce the attack surface\n   */\n  static getRel({ target, rel }: { target?: string; rel?: string }) {\n    const relProp: string[] = []\n    if (rel) {\n      relProp.push(rel)\n    }\n    if (target === '_blank') {\n      relProp.push('noopener')\n    }\n    if (relProp.length) {\n      return relProp.join(' ')\n    }\n    return undefined\n  }\n\n  constructor(props: UnstyledButtonProps) {\n    super(props)\n    this.buttonRef = props.getRef || createRef()\n  }\n\n  buttonRef: React.RefObject<HTMLElement>\n\n  _onKeyPress = (event: KeyboardEvent<HTMLButtonElement>) => {\n    const { component, disabled, loading, onClick, onKeyPress } = this.props\n    if (!disabled && !loading) {\n      if (\n        onClick &&\n        ['Enter', ' '].includes(event.key) &&\n        component !== 'button'\n      ) {\n        event.preventDefault()\n        onClick(event)\n        return\n      }\n      if (onKeyPress) {\n        onKeyPress(event)\n      }\n    }\n  }\n\n  _onClick = (event: SyntheticEvent<HTMLButtonElement>) => {\n    const { disabled, loading, onClick, blurOnClick } = this.props\n    if (!disabled && !loading && onClick) {\n      onClick(event)\n    }\n    if (blurOnClick) {\n      if (this.buttonRef && this.buttonRef.current) {\n        this.buttonRef.current.blur()\n      }\n    }\n  }\n\n  componentDidMount() {\n    if (this.props.autofocus) {\n      this.buttonRef && this.buttonRef.current && this.buttonRef.current.focus()\n    }\n  }\n\n  render() {\n    const {\n      children,\n      component: ButtonComponent,\n      'data-instrumentation': dataInstrumentation,\n      disabled,\n      disabledTitle,\n      loading,\n      rel,\n      target,\n      title,\n      ...props\n    } = this.props\n\n    const buttonProps = omit(props, [\n      'autofocus',\n      'borderless',\n      'borderlessAlt',\n      'blurOnClick',\n      'circle',\n      'danger',\n      'dangerAlt',\n      'ignoreFocus',\n      'colorFocus',\n      'hoverless',\n      'icon',\n      'loading',\n      'plain',\n      'primary',\n      'small',\n      'square',\n      'getRef'\n    ])\n\n    return (\n      <ButtonComponent\n        tabIndex={disabled ? -1 : 0}\n        role=\"button\"\n        {...buttonProps}\n        data-instrumentation={dataInstrumentation}\n        disabled={loading || disabled}\n        onClick={this._onClick}\n        onKeyPress={this._onKeyPress}\n        ref={this.buttonRef}\n        rel={UnstyledButton.getRel({ rel, target })}\n        title={disabled ? disabledTitle : title}\n        target={target}\n      >\n        {children}\n        {loading && <Spinner />}\n      </ButtonComponent>\n    )\n  }\n}\n\nconst StyledButton = styled(UnstyledButton)(styles)\nexport const Button = forwardRef<UnstyledButton, Partial<UnstyledButtonProps>>(\n  (props, ref) => <StyledButton getRef={ref} {...props} />\n)\nButton.displayName = 'Button'\n\nexport default Button\n"]} */");
440
+ })(styles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Button/Button.tsx"],"names":[],"mappings":"AAyfqB","file":"../../../src/Button/Button.tsx","sourcesContent":["import React, {\n  Component,\n  forwardRef,\n  createRef,\n  ReactNode,\n  ComponentType,\n  SyntheticEvent,\n  KeyboardEvent\n} from 'react'\nimport color from 'color'\nimport styled from '@emotion/styled'\nimport omit from 'lodash.omit'\nimport { multiply } from '../utils'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\nimport { Spinner } from './elements'\n\nconst styles: Array<(props: any) => any> = [\n  // reset\n  ({\n    disabled,\n    theme\n  }: {\n    ignoreFocus: boolean\n    disabled: boolean\n    loading: boolean\n    theme: Theme\n  }) => ({\n    alignItems: 'center',\n    backgroundColor: 'transparent',\n    border: '1px solid transparent',\n    cursor: disabled ? 'default' : 'pointer',\n    display: 'inline-flex',\n    flexShrink: 0,\n    fontFamily: theme.fontFamily.body,\n    justifyContent: 'center',\n    margin: 0,\n    padding: 0,\n    position: 'relative',\n    textAlign: 'center',\n    textDecoration: 'none',\n    textRendering: 'optimizeLegibility',\n    touchAction: 'manipulation',\n    userSelect: 'none',\n    verticalAlign: 'middle',\n    whiteSpace: 'nowrap'\n  }),\n  // default outline\n  ({\n    theme,\n    plain,\n    icon,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    plain: boolean\n    icon: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    !plain &&\n    !icon && {\n      backgroundColor: theme.palette.neutral[0],\n      border: disabled\n        ? `1px solid ${color(theme.palette.primary[4]).alpha(0.3).string()}`\n        : `1px solid ${theme.palette.primary[4]}`,\n      borderRadius: theme.radius[4],\n      color: disabled\n        ? color(theme.palette.primary[4]).alpha(0.3).string()\n        : theme.palette.primary[4],\n      fontSize: theme.fontSize[0],\n      fontWeight: 600,\n      height: theme.space[8],\n      lineHeight: theme.lineHeight[4],\n      overflow: 'hidden',\n      padding: `0 ${theme.space[4]}`,\n      textOverflow: 'ellipsis',\n      outline: 'none',\n      textTransform: 'unset',\n      transition: 'transform 0.15s ease-in-out',\n      ':hover': !disabled &&\n        !loading && {\n          boxShadow: '0px 2px 7px rgba(0, 0, 0, 0.2)',\n          transform: 'translateY(-1px)'\n        },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: theme.palette.primary[0],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.primary[4])\n            .darken(0.1)\n            .string()}`\n        }\n    },\n\n  // primary\n  ({\n    theme,\n    primary,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    primary: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    primary && {\n      backgroundColor: disabled\n        ? color(theme.palette.primary[4]).alpha(0.3).string()\n        : theme.palette.primary[4],\n      color: theme.palette.neutral[0],\n      borderColor: 'transparent',\n      ':hover': !disabled &&\n        !loading && {\n          backgroundColor: color(theme.palette.primary[4])\n            .lighten(0.4)\n            .string(),\n          boxShadow: `0 2px 7px ${color(theme.palette.primary[4])\n            .lighten(0.4)\n            .alpha(0.35)\n            .string()}`\n        },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: theme.palette.primary[5],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.primary[5])\n            .darken(0.425)\n            .string()}`,\n          color: theme.palette.neutral[0]\n        }\n    },\n\n  // borderless\n  ({\n    theme,\n    borderless,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    borderless: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    borderless && {\n      backgroundColor: 'transparent',\n      border: 'none',\n      color: disabled\n        ? color(theme.palette.primary[4]).alpha(0.3).string()\n        : theme.palette.primary[4],\n      borderColor: 'none',\n      ':hover': !disabled &&\n        !loading && {\n          boxShadow: 'none',\n          textDecoration: 'underline',\n          transform: 'none'\n        },\n      ':active': !disabled &&\n        !loading && {\n          background: 'transparent',\n          boxShadow: 'none'\n        }\n    },\n  // borderless Alt\n  ({\n    theme,\n    borderlessAlt,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    borderlessAlt: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    borderlessAlt && {\n      background: 'transparent',\n      color: disabled\n        ? color(theme.palette.neutral[0]).alpha(0.5).string()\n        : theme.palette.neutral[0],\n      borderColor: 'none',\n      border: 'none',\n      ':hover': !disabled &&\n        !loading && {\n          boxShadow: `none`,\n          textDecoration: 'underline',\n          transform: 'none'\n        },\n      ':active': !disabled &&\n        !loading && {\n          background: 'transparent',\n          textDecoration: 'underline'\n        }\n    },\n  // icon\n  ({ theme, icon, small }: { theme: Theme; icon: boolean; small: boolean }) =>\n    icon && {\n      borderRadius: 0,\n      height: 'auto',\n      padding: 0,\n      minHeight: small\n        ? multiply(theme.space[2], 2.5)\n        : multiply(theme.space[3], 3),\n      minWidth: small\n        ? multiply(theme.space[2], 2.5)\n        : multiply(theme.space[3], 3)\n    },\n  // circle\n  ({ theme, circle }: { theme: Theme; circle: boolean }) =>\n    circle && {\n      borderRadius: '50%',\n      height: multiply(theme.space[3], 2),\n      lineHeight: theme.lineHeight[4],\n      padding: 0,\n      overflow: 'hidden',\n      width: multiply(theme.space[3], 2),\n      ':hover': {\n        transform: 'none'\n      }\n    },\n  // danger\n  ({\n    theme,\n    danger,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    danger: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    danger && {\n      backgroundColor: disabled\n        ? color(theme.palette.error[1]).alpha(0.3).string()\n        : theme.palette.error[1],\n      color: theme.palette.neutral[0],\n      border: 'none',\n      ':hover': !disabled &&\n        !loading && {\n          backgroundColor: color(theme.palette.error[1]).lighten(0.2).string(),\n          boxShadow: `0 2px 7px ${color(theme.palette.error[1])\n            .lighten(0.2)\n            .string()}`\n        },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: color(theme.palette.error[1]).darken(0.1).string(),\n          borderColor: 'transparent',\n          color: theme.palette.neutral[0],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.error[1])\n            .darken(0.3)\n            .string()}`\n        }\n    },\n  // dangerAlt\n  ({\n    theme,\n    dangerAlt,\n    disabled,\n    loading\n  }: {\n    theme: Theme\n    dangerAlt: boolean\n    disabled: boolean\n    loading: boolean\n  }) =>\n    dangerAlt && {\n      backgroundColor: disabled\n        ? color(theme.palette.neutral[0]).alpha(0.5).string()\n        : theme.palette.neutral[0],\n      color: theme.palette.error[1],\n      border: 'none',\n      ':hover': !disabled &&\n        !loading && { boxShadow: `0 2px 7px rgba(0, 0, 0, 0.5)` },\n      ':active': !disabled &&\n        !loading && {\n          backgroundColor: theme.palette.neutral[0],\n          borderColor: 'transparent',\n          color: theme.palette.error[1],\n          boxShadow: `inset 0px 2px 4px ${color(theme.palette.neutral[0])\n            .darken(0.3)\n            .string()}`\n        }\n    },\n  // loading\n  ({ theme, loading }: { theme: Theme; loading: boolean }) =>\n    loading && {\n      backgroundColor: theme.palette.neutral[3],\n      border: 'none',\n      color: theme.palette.neutral[9],\n      cursor: 'default'\n    },\n  // noFocus\n  ({ ignoreFocus }: { ignoreFocus: boolean }) =>\n    ignoreFocus && {\n      outline: 'none',\n      ':focus': {\n        outline: 'none'\n      }\n    },\n  // coloredFocus\n  ({ theme, colorFocus }: { theme: Theme; colorFocus: boolean }) =>\n    colorFocus && {\n      outline: 'none',\n      ':focus': {\n        outline: 'none',\n        color: theme.palette.primary[4]\n      }\n    },\n  getOverrides(Overridable.Button.Root)\n]\n\nexport type UnstyledButtonProps = {\n  /** Focus the button when it's rendered */\n  autofocus?: boolean\n  /** Unfocus the button when it's clicked */\n  blurOnClick?: boolean\n  /** Text Button */\n  borderless?: boolean\n  /** Text Button on non-white Background */\n  borderlessAlt?: boolean\n  children: ReactNode\n  /** Enable circle style */\n  circle?: boolean\n  className?: string\n  /** Removes outline and changes color to Primary on focus */\n  colorFocus?: boolean\n  /** Stateful component or html tag to render as (defaults to `button`) */\n  component: ComponentType<any> | string\n  /** Enable danger style */\n  danger?: boolean\n  /** Instrumentation */\n  'data-instrumentation'?: string\n  /** Enable dangerAlt style --- white background */\n  dangerAlt?: boolean\n  /** Enable disabled style */\n  disabled?: boolean\n  /** Title to display when button is disabled */\n  disabledTitle?: string\n  getRef?: React.RefObject<HTMLElement>\n  form?: string\n  href?: string\n  id?: string\n  /** Enable styles suitible for wrapping icons */\n  icon?: boolean\n  /** Prevent button from being focused */\n  ignoreFocus?: boolean\n  loading?: boolean\n  onClick?: (event: SyntheticEvent<HTMLButtonElement>) => void\n  onKeyPress?: (event: KeyboardEvent<HTMLButtonElement>) => void\n  onMouseDown?: (event: KeyboardEvent<HTMLButtonElement>) => void\n  /** Disable default button styles */\n  plain?: boolean\n  /** Fill button with solid color */\n  primary?: boolean\n  rel?: string\n  /** Only used with `icon`. */\n  small?: boolean\n  target?: string\n  theme?: Theme\n  /** Title to display when button is enabled */\n  title?: string\n  /** HTML button type attribute */\n  type?: React.ButtonHTMLAttributes<HTMLButtonElement>['type']\n  hasError?: boolean\n  /** Indicates whether the button should not have a special visual appearance when mouse hovers above it. */\n  hoverless?: boolean\n}\n\nexport class UnstyledButton extends Component<UnstyledButtonProps> {\n  static defaultProps = {\n    borderless: false,\n    borderlessAlt: false,\n    blurOnClick: false,\n    circle: false,\n    component: 'button',\n    danger: false,\n    dangerAlt: false,\n    'data-instrumentation': 'button',\n    disabled: false,\n    loading: false,\n    small: false,\n    primary: false,\n    hoverless: false\n  }\n\n  /**\n   * https://mathiasbynens.github.io/rel-noopener/\n   * Using target=_blank is insecure, so we add\n   * rel=noopener to reduce the attack surface\n   */\n  static getRel({ target, rel }: { target?: string; rel?: string }) {\n    const relProp: string[] = []\n    if (rel) {\n      relProp.push(rel)\n    }\n    if (target === '_blank') {\n      relProp.push('noopener')\n    }\n    if (relProp.length) {\n      return relProp.join(' ')\n    }\n    return undefined\n  }\n\n  constructor(props: UnstyledButtonProps) {\n    super(props)\n    this.buttonRef = props.getRef || createRef()\n  }\n\n  buttonRef: React.RefObject<HTMLElement>\n\n  _onKeyPress = (event: KeyboardEvent<HTMLButtonElement>) => {\n    const { component, disabled, loading, onClick, onKeyPress } = this.props\n    if (!disabled && !loading) {\n      if (\n        onClick &&\n        ['Enter', ' '].includes(event.key) &&\n        component !== 'button'\n      ) {\n        event.preventDefault()\n        onClick(event)\n        return\n      }\n      if (onKeyPress) {\n        onKeyPress(event)\n      }\n    }\n  }\n\n  _onClick = (event: SyntheticEvent<HTMLButtonElement>) => {\n    const { disabled, loading, onClick, blurOnClick } = this.props\n    if (!disabled && !loading && onClick) {\n      onClick(event)\n    }\n    if (blurOnClick) {\n      if (this.buttonRef && this.buttonRef.current) {\n        this.buttonRef.current.blur()\n      }\n    }\n  }\n\n  componentDidMount() {\n    if (this.props.autofocus) {\n      this.buttonRef && this.buttonRef.current && this.buttonRef.current.focus()\n    }\n  }\n\n  render() {\n    const {\n      children,\n      component: ButtonComponent,\n      'data-instrumentation': dataInstrumentation,\n      disabled,\n      disabledTitle,\n      loading,\n      rel,\n      target,\n      title,\n      ...props\n    } = this.props\n\n    const buttonProps = omit(props, [\n      'autofocus',\n      'borderless',\n      'borderlessAlt',\n      'blurOnClick',\n      'circle',\n      'danger',\n      'dangerAlt',\n      'ignoreFocus',\n      'colorFocus',\n      'hoverless',\n      'icon',\n      'loading',\n      'plain',\n      'primary',\n      'small',\n      'square',\n      'getRef'\n    ])\n\n    return (\n      <ButtonComponent\n        tabIndex={disabled ? -1 : 0}\n        role=\"button\"\n        {...buttonProps}\n        data-instrumentation={dataInstrumentation}\n        disabled={loading || disabled}\n        onClick={this._onClick}\n        onKeyPress={this._onKeyPress}\n        ref={this.buttonRef}\n        rel={UnstyledButton.getRel({ rel, target })}\n        title={disabled ? disabledTitle : title}\n        target={target}\n      >\n        {children}\n        {loading && <Spinner />}\n      </ButtonComponent>\n    )\n  }\n}\n\nconst StyledButton = styled(UnstyledButton)(styles)\n// eslint-disable-next-line react/display-name\nexport const Button = forwardRef<UnstyledButton, Partial<UnstyledButtonProps>>(\n  (props, ref) => <StyledButton getRef={ref} {...props} />\n)\n\nexport default Button\n"]} */"); // eslint-disable-next-line react/display-name
441
+
441
442
  var Button = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
442
443
  return (0, _jsxRuntime.jsx)(StyledButton, _objectSpread({
443
444
  "data-gs": gs("src", "button", "button.tsx", "styled-button"),
@@ -445,6 +446,5 @@ var Button = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
445
446
  }, props));
446
447
  });
447
448
  exports.Button = Button;
448
- Button.displayName = 'Button';
449
449
  var _default = Button;
450
450
  exports["default"] = _default;
@@ -92,7 +92,6 @@ var Grid = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "
92
92
  return areas && {
93
93
  gridTemplateAreas: "".concat(formatAreas(areas))
94
94
  };
95
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9HcmlkL0dyaWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlEYSIsImZpbGUiOiIuLi8uLi8uLi9zcmMvR3JpZC9HcmlkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuXG5leHBvcnQgdHlwZSBHcmlkUHJvcHMgPSB7XG4gIC8qKiBBbGlnbnMgdGhlIGdyaWQgYWxvbmcgdGhlIGNvbHVtbiBheGlzICBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvYWxpZ24tY29udGVudCAqL1xuICBhbGlnbkNvbnRlbnQ/OlxuICAgIHwgJ3N0YXJ0J1xuICAgIHwgJ2NlbnRlcidcbiAgICB8ICdlbmQnXG4gICAgfCAnc3BhY2UtYmV0d2VlbidcbiAgICB8ICdzcGFjZS1hcm91bmQnXG4gICAgfCAnc3RyZXRjaCdcbiAgICB8ICdzcGFjZS1ldmVubHknXG4gIC8qKiBBbGlnbiBpdGVtcyBhbG9uZyB0aGUgY29sdW1uIGF4aXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2FsaWduLWl0ZW1zICovXG4gIGFsaWduSXRlbXM/OiAnc3RhcnQnIHwgJ2NlbnRlcicgfCAnZW5kJyB8ICdzdHJldGNoJ1xuICAvKiogRGVmaW5lIGN1c3RvbSBhcmVhcyBvZiB0aGUgZ3JpZCwgYWxsb3dpbmcgZm9yIHBsYWNlbWVudCBvZiBHcmlkSXRlbXMgaW4gdGhvc2UgYXJlYXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtdGVtcGxhdGUtYXJlYXMgKi9cbiAgYXJlYXM/OiBzdHJpbmdbXVxuXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAvKiogc3BhY2UgYmV0d2VlbiBjb2x1bW5zIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9jb2x1bW4tZ2FwICovXG4gIGNvbHVtbkdhcD86IHN0cmluZ1xuICAvKiogUGFzc2luZyBpbiBhIG51bWJlciBnaXZlcyB0aGUgc3BlY2lmaWVkIG51bWJlciBvZiBjb2x1bW5zIGF0IDFmciwgYW5kIHBhc3NpbmcgaW4gYSBzdHJpbmcgZ2l2ZXMgYSBtb3JlIGN1c3RvbWl6ZWQgdmFsdWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtdGVtcGxhdGUtY29sdW1ucyAqL1xuICBjb2x1bW5zPzogc3RyaW5nIHwgbnVtYmVyXG4gIC8qKiBBdXRvIHBsYWNlIGdyaWQgaXRlbXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtYXV0by1mbG93ICovXG4gIGZsb3c/OiAncm93JyB8ICdjb2x1bW4nIHwgJ3JvdyBkZW5zZScgfCAnY29sdW1uIGRlbnNlJ1xuICAvKiogc3BhY2UgYmV0d2VlbiBjb2x1bW5zIGFuZCByb3dzIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9nYXAgKi9cbiAgZ2FwPzogc3RyaW5nXG4gIC8qKiBoZWlnaHQgb2YgdGhlIGdyaWQgKi9cbiAgaGVpZ2h0Pzogc3RyaW5nIHwgbnVtYmVyXG4gIC8qKiBBbGlnbnMgZ3JpZCBhbG9uZyB0aGUgcm93IGF4aXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2p1c3RpZnktY29udGVudCAqL1xuICBqdXN0aWZ5Q29udGVudD86XG4gICAgfCAnc3RhcnQnXG4gICAgfCAnY2VudGVyJ1xuICAgIHwgJ3N0cmV0Y2gnXG4gICAgfCAnc3BhY2UtYmV0d2VlbidcbiAgICB8ICdzcGFjZS1hcm91bmQnXG4gICAgfCAnc3BhY2UtZXZlbmx5J1xuICAgIHwgJ2VuZCdcbiAgLyoqIGFsaWduIGl0ZW1zIGFsb25nIHRoZSByb3cgYXhpcy4gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2p1c3RpZnktaXRlbXMgKi9cbiAganVzdGlmeUl0ZW1zPzogJ3N0YXJ0JyB8ICdjZW50ZXInIHwgJ2VuZCcgfCAnc3RyZXRjaCdcbiAgLyoqIEZvciB1c2Ugd2l0aCBnZW5lcmF0aW5nIHJvd3MsIG11c3QgYmUgYSBzdHJpbmcgKi9cbiAgbWluUm93SGVpZ2h0Pzogc3RyaW5nXG4gIC8qKiBzcGFjZSBiZXR3ZWVuIHJvd3MgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL3Jvdy1nYXAgKi9cbiAgcm93R2FwPzogc3RyaW5nXG4gIC8qKiBQYXNzaW5nIGluIGEgbnVtYmVyIGdpdmVzIHRoZSBzcGVjaWZpZWQgbnVtYmVyIG9mIHJvd3MgYXQgMWZyLCBhbmQgcGFzc2luZyBpbiBhIHN0cmluZyBnaXZlcyBhIG1vcmUgY3VzdG9taXplZCB2YWx1ZSBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvZ3JpZC10ZW1wbGF0ZS1yb3dzICovXG4gIHJvd3M/OiBzdHJpbmcgfCBudW1iZXJcbiAgLyoqIHdpZHRoIG9mIHRoZSBncmlkICovXG4gIHdpZHRoPzogc3RyaW5nIHwgbnVtYmVyXG59XG5cbmNvbnN0IGF1dG9Sb3dzID0gKG1pblJvd0hlaWdodDogc3RyaW5nKSA9PiBgbWlubWF4KCR7bWluUm93SGVpZ2h0fSwgYXV0bylgXG5cbmNvbnN0IGZyR2V0dGVyID0gKHZhbHVlOiBzdHJpbmcgfCBudW1iZXIpID0+XG4gIHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicgPyBgcmVwZWF0KCR7dmFsdWV9LCAxZnIpYCA6IHZhbHVlXG5cbmNvbnN0IGZvcm1hdEFyZWFzID0gKGFyZWFzOiBzdHJpbmdbXSkgPT5cbiAgYXJlYXMubWFwKGFyZWEgPT4gYFwiJHthcmVhfVwiYCkuam9pbignICcpXG5cbmNvbnN0IEdyaWQgPSBzdHlsZWQoJ2RpdicpPEdyaWRQcm9wcz4oXG4gICh7IHRoZW1lLCBjb2x1bW5zID0gNCwgZ2FwLCBoZWlnaHQsIGZsb3csIHdpZHRoIH0pID0+ICh7XG4gICAgZGlzcGxheTogJ2dyaWQnLFxuICAgIGhlaWdodDogaGVpZ2h0IHx8ICdhdXRvJyxcbiAgICB3aWR0aDogd2lkdGggfHwgJzEwMCUnLFxuICAgIGdyaWRHYXA6IGdhcCB8fCB0aGVtZS5zcGFjZVszXSxcbiAgICBncmlkQXV0b0Zsb3c6IGZsb3cgfHwgJ3JvdycsXG4gICAgZ3JpZFRlbXBsYXRlQ29sdW1uczogZnJHZXR0ZXIoY29sdW1ucylcbiAgfSksXG4gICh7IGFsaWduQ29udGVudCB9KSA9PlxuICAgIGFsaWduQ29udGVudCAmJiB7XG4gICAgICBhbGlnbkNvbnRlbnRcbiAgICB9LFxuICAoeyBhbGlnbkl0ZW1zIH0pID0+XG4gICAgYWxpZ25JdGVtcyAmJiB7XG4gICAgICBhbGlnbkl0ZW1zXG4gICAgfSxcbiAgKHsganVzdGlmeUNvbnRlbnQgfSkgPT5cbiAgICBqdXN0aWZ5Q29udGVudCAmJiB7XG4gICAgICBqdXN0aWZ5Q29udGVudFxuICAgIH0sXG4gICh7IGp1c3RpZnlJdGVtcyB9KSA9PlxuICAgIGp1c3RpZnlJdGVtcyAmJiB7XG4gICAgICBqdXN0aWZ5SXRlbXNcbiAgICB9LFxuICAoeyBtaW5Sb3dIZWlnaHQgfSkgPT5cbiAgICBtaW5Sb3dIZWlnaHQgJiYge1xuICAgICAgZ3JpZEF1dG9Sb3dzOiBhdXRvUm93cyhtaW5Sb3dIZWlnaHQpXG4gICAgfSxcbiAgKHsgcm93cyB9KSA9PlxuICAgIHJvd3MgJiYge1xuICAgICAgZ3JpZFRlbXBsYXRlUm93czogZnJHZXR0ZXIocm93cylcbiAgICB9LFxuICAoeyBjb2x1bW5HYXAgfSkgPT5cbiAgICBjb2x1bW5HYXAgJiYge1xuICAgICAgY29sdW1uR2FwXG4gICAgfSxcbiAgKHsgcm93R2FwIH0pID0+XG4gICAgcm93R2FwICYmIHtcbiAgICAgIHJvd0dhcFxuICAgIH0sXG4gICh7IGFyZWFzIH0pID0+XG4gICAgYXJlYXMgJiYge1xuICAgICAgZ3JpZFRlbXBsYXRlQXJlYXM6IGAke2Zvcm1hdEFyZWFzKGFyZWFzKX1gXG4gICAgfVxuKVxuR3JpZC5kaXNwbGF5TmFtZSA9ICdHcmlkJ1xuXG5leHBvcnQgZGVmYXVsdCBHcmlkXG4iXX0= */");
96
- Grid.displayName = 'Grid';
95
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9HcmlkL0dyaWQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlEYSIsImZpbGUiOiIuLi8uLi8uLi9zcmMvR3JpZC9HcmlkLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuXG5leHBvcnQgdHlwZSBHcmlkUHJvcHMgPSB7XG4gIC8qKiBBbGlnbnMgdGhlIGdyaWQgYWxvbmcgdGhlIGNvbHVtbiBheGlzICBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvYWxpZ24tY29udGVudCAqL1xuICBhbGlnbkNvbnRlbnQ/OlxuICAgIHwgJ3N0YXJ0J1xuICAgIHwgJ2NlbnRlcidcbiAgICB8ICdlbmQnXG4gICAgfCAnc3BhY2UtYmV0d2VlbidcbiAgICB8ICdzcGFjZS1hcm91bmQnXG4gICAgfCAnc3RyZXRjaCdcbiAgICB8ICdzcGFjZS1ldmVubHknXG4gIC8qKiBBbGlnbiBpdGVtcyBhbG9uZyB0aGUgY29sdW1uIGF4aXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2FsaWduLWl0ZW1zICovXG4gIGFsaWduSXRlbXM/OiAnc3RhcnQnIHwgJ2NlbnRlcicgfCAnZW5kJyB8ICdzdHJldGNoJ1xuICAvKiogRGVmaW5lIGN1c3RvbSBhcmVhcyBvZiB0aGUgZ3JpZCwgYWxsb3dpbmcgZm9yIHBsYWNlbWVudCBvZiBHcmlkSXRlbXMgaW4gdGhvc2UgYXJlYXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtdGVtcGxhdGUtYXJlYXMgKi9cbiAgYXJlYXM/OiBzdHJpbmdbXVxuXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAvKiogc3BhY2UgYmV0d2VlbiBjb2x1bW5zIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9jb2x1bW4tZ2FwICovXG4gIGNvbHVtbkdhcD86IHN0cmluZ1xuICAvKiogUGFzc2luZyBpbiBhIG51bWJlciBnaXZlcyB0aGUgc3BlY2lmaWVkIG51bWJlciBvZiBjb2x1bW5zIGF0IDFmciwgYW5kIHBhc3NpbmcgaW4gYSBzdHJpbmcgZ2l2ZXMgYSBtb3JlIGN1c3RvbWl6ZWQgdmFsdWUgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtdGVtcGxhdGUtY29sdW1ucyAqL1xuICBjb2x1bW5zPzogc3RyaW5nIHwgbnVtYmVyXG4gIC8qKiBBdXRvIHBsYWNlIGdyaWQgaXRlbXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtYXV0by1mbG93ICovXG4gIGZsb3c/OiAncm93JyB8ICdjb2x1bW4nIHwgJ3JvdyBkZW5zZScgfCAnY29sdW1uIGRlbnNlJ1xuICAvKiogc3BhY2UgYmV0d2VlbiBjb2x1bW5zIGFuZCByb3dzIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9nYXAgKi9cbiAgZ2FwPzogc3RyaW5nXG4gIC8qKiBoZWlnaHQgb2YgdGhlIGdyaWQgKi9cbiAgaGVpZ2h0Pzogc3RyaW5nIHwgbnVtYmVyXG4gIC8qKiBBbGlnbnMgZ3JpZCBhbG9uZyB0aGUgcm93IGF4aXMgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2p1c3RpZnktY29udGVudCAqL1xuICBqdXN0aWZ5Q29udGVudD86XG4gICAgfCAnc3RhcnQnXG4gICAgfCAnY2VudGVyJ1xuICAgIHwgJ3N0cmV0Y2gnXG4gICAgfCAnc3BhY2UtYmV0d2VlbidcbiAgICB8ICdzcGFjZS1hcm91bmQnXG4gICAgfCAnc3BhY2UtZXZlbmx5J1xuICAgIHwgJ2VuZCdcbiAgLyoqIGFsaWduIGl0ZW1zIGFsb25nIHRoZSByb3cgYXhpcy4gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2p1c3RpZnktaXRlbXMgKi9cbiAganVzdGlmeUl0ZW1zPzogJ3N0YXJ0JyB8ICdjZW50ZXInIHwgJ2VuZCcgfCAnc3RyZXRjaCdcbiAgLyoqIEZvciB1c2Ugd2l0aCBnZW5lcmF0aW5nIHJvd3MsIG11c3QgYmUgYSBzdHJpbmcgKi9cbiAgbWluUm93SGVpZ2h0Pzogc3RyaW5nXG4gIC8qKiBzcGFjZSBiZXR3ZWVuIHJvd3MgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL3Jvdy1nYXAgKi9cbiAgcm93R2FwPzogc3RyaW5nXG4gIC8qKiBQYXNzaW5nIGluIGEgbnVtYmVyIGdpdmVzIHRoZSBzcGVjaWZpZWQgbnVtYmVyIG9mIHJvd3MgYXQgMWZyLCBhbmQgcGFzc2luZyBpbiBhIHN0cmluZyBnaXZlcyBhIG1vcmUgY3VzdG9taXplZCB2YWx1ZSBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvZ3JpZC10ZW1wbGF0ZS1yb3dzICovXG4gIHJvd3M/OiBzdHJpbmcgfCBudW1iZXJcbiAgLyoqIHdpZHRoIG9mIHRoZSBncmlkICovXG4gIHdpZHRoPzogc3RyaW5nIHwgbnVtYmVyXG59XG5cbmNvbnN0IGF1dG9Sb3dzID0gKG1pblJvd0hlaWdodDogc3RyaW5nKSA9PiBgbWlubWF4KCR7bWluUm93SGVpZ2h0fSwgYXV0bylgXG5cbmNvbnN0IGZyR2V0dGVyID0gKHZhbHVlOiBzdHJpbmcgfCBudW1iZXIpID0+XG4gIHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicgPyBgcmVwZWF0KCR7dmFsdWV9LCAxZnIpYCA6IHZhbHVlXG5cbmNvbnN0IGZvcm1hdEFyZWFzID0gKGFyZWFzOiBzdHJpbmdbXSkgPT5cbiAgYXJlYXMubWFwKGFyZWEgPT4gYFwiJHthcmVhfVwiYCkuam9pbignICcpXG5cbmNvbnN0IEdyaWQgPSBzdHlsZWQoJ2RpdicpPEdyaWRQcm9wcz4oXG4gICh7IHRoZW1lLCBjb2x1bW5zID0gNCwgZ2FwLCBoZWlnaHQsIGZsb3csIHdpZHRoIH0pID0+ICh7XG4gICAgZGlzcGxheTogJ2dyaWQnLFxuICAgIGhlaWdodDogaGVpZ2h0IHx8ICdhdXRvJyxcbiAgICB3aWR0aDogd2lkdGggfHwgJzEwMCUnLFxuICAgIGdyaWRHYXA6IGdhcCB8fCB0aGVtZS5zcGFjZVszXSxcbiAgICBncmlkQXV0b0Zsb3c6IGZsb3cgfHwgJ3JvdycsXG4gICAgZ3JpZFRlbXBsYXRlQ29sdW1uczogZnJHZXR0ZXIoY29sdW1ucylcbiAgfSksXG4gICh7IGFsaWduQ29udGVudCB9KSA9PlxuICAgIGFsaWduQ29udGVudCAmJiB7XG4gICAgICBhbGlnbkNvbnRlbnRcbiAgICB9LFxuICAoeyBhbGlnbkl0ZW1zIH0pID0+XG4gICAgYWxpZ25JdGVtcyAmJiB7XG4gICAgICBhbGlnbkl0ZW1zXG4gICAgfSxcbiAgKHsganVzdGlmeUNvbnRlbnQgfSkgPT5cbiAgICBqdXN0aWZ5Q29udGVudCAmJiB7XG4gICAgICBqdXN0aWZ5Q29udGVudFxuICAgIH0sXG4gICh7IGp1c3RpZnlJdGVtcyB9KSA9PlxuICAgIGp1c3RpZnlJdGVtcyAmJiB7XG4gICAgICBqdXN0aWZ5SXRlbXNcbiAgICB9LFxuICAoeyBtaW5Sb3dIZWlnaHQgfSkgPT5cbiAgICBtaW5Sb3dIZWlnaHQgJiYge1xuICAgICAgZ3JpZEF1dG9Sb3dzOiBhdXRvUm93cyhtaW5Sb3dIZWlnaHQpXG4gICAgfSxcbiAgKHsgcm93cyB9KSA9PlxuICAgIHJvd3MgJiYge1xuICAgICAgZ3JpZFRlbXBsYXRlUm93czogZnJHZXR0ZXIocm93cylcbiAgICB9LFxuICAoeyBjb2x1bW5HYXAgfSkgPT5cbiAgICBjb2x1bW5HYXAgJiYge1xuICAgICAgY29sdW1uR2FwXG4gICAgfSxcbiAgKHsgcm93R2FwIH0pID0+XG4gICAgcm93R2FwICYmIHtcbiAgICAgIHJvd0dhcFxuICAgIH0sXG4gICh7IGFyZWFzIH0pID0+XG4gICAgYXJlYXMgJiYge1xuICAgICAgZ3JpZFRlbXBsYXRlQXJlYXM6IGAke2Zvcm1hdEFyZWFzKGFyZWFzKX1gXG4gICAgfVxuKVxuXG5leHBvcnQgZGVmYXVsdCBHcmlkXG4iXX0= */");
97
96
  var _default = Grid;
98
97
  exports["default"] = _default;
@@ -64,7 +64,6 @@ var GridItem = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV =
64
64
  return center && {
65
65
  textAlign: 'center'
66
66
  };
67
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9HcmlkL0dyaWRJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QmlCIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9HcmlkL0dyaWRJdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuXG5leHBvcnQgdHlwZSBHcmlkSXRlbVByb3BzID0ge1xuICAvKiogQWxpZ25zIGl0ZW0gYWxvbmcgdGhlIGNvbHVtbiBheGlzIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9hbGlnbi1zZWxmICovXG4gIGFsaWduU2VsZj86ICdzdGFydCcgfCAnY2VudGVyJyB8ICdlbmQnIHwgJ3N0cmV0Y2gnXG4gIC8qKiBwbGFjZXMgaXRlbSBpbiBhIHNwZWNpZmljIGFyZWEgb2YgdGhlIGdyaWQgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtYXJlYSAqL1xuICBhcmVhPzogc3RyaW5nXG4gIC8qKiBDZW50ZXIgY29udGVudCBob3Jpem9udGFsbHkgKi9cbiAgY2VudGVyPzogYm9vbGVhblxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgLyoqIE51bWJlciBvZiBjb2x1bW5zIGl0ZW0gd2lsbCBzcGFuIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLWNvbHVtbi1lbmQgKi9cbiAgY29sV2lkdGg/OiBudW1iZXJcbiAgLyoqIEFsaWducyBpdGVtIGFsb25nIHRoZSByb3cgYXhpcyBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvanVzdGlmeS1zZWxmICovXG4gIGp1c3RpZnlTZWxmPzogJ3N0YXJ0JyB8ICdjZW50ZXInIHwgJ2VuZCcgfCAnc3RyZXRjaCdcbiAgLyoqIFdoZXJlIGluIHRoZSBncmlkIGNvbHVtbiB0aGUgaXRlbSBzaG91bGQgc3RhcnQgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtY29sdW1uLXN0YXJ0ICovXG4gIGxlZnQ/OiBudW1iZXIgfCBzdHJpbmdcbiAgLyoqIENlbnRlciBjb250ZW50IHZlcnRpY2FsbHkgKi9cbiAgbWlkZGxlPzogYm9vbGVhblxuICAvKiogTnVtYmVyIG9mIHJvd3MgaXRlbSB3aWxsIHNwYW4gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtcm93LWVuZCAqL1xuICByb3dIZWlnaHQ/OiBudW1iZXJcbiAgLyoqIFdoZXJlIGluIHRoZSBncmlkIHJvdyB0aGUgaXRlbSBzaG91bGQgc3RhcnQgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtcm93LXN0YXJ0ICovXG4gIHRvcD86IG51bWJlciB8IHN0cmluZ1xufVxuXG5jb25zdCBHcmlkSXRlbSA9IHN0eWxlZCgnZGl2Jyk8R3JpZEl0ZW1Qcm9wcz4oXG4gICh7IHJvd0hlaWdodCA9IDEsIGNvbFdpZHRoID0gMSB9KSA9PiAoe1xuICAgIG1pbldpZHRoOiAwLFxuICAgIGdyaWRDb2x1bW5FbmQ6IGBzcGFuICR7Y29sV2lkdGh9YCxcbiAgICBncmlkUm93RW5kOiBgc3BhbiAke3Jvd0hlaWdodH1gXG4gIH0pLFxuICAoeyBhbGlnblNlbGYgfSkgPT5cbiAgICBhbGlnblNlbGYgJiYge1xuICAgICAgYWxpZ25TZWxmXG4gICAgfSxcbiAgKHsganVzdGlmeVNlbGYgfSkgPT5cbiAgICBqdXN0aWZ5U2VsZiAmJiB7XG4gICAgICBqdXN0aWZ5U2VsZlxuICAgIH0sXG4gICh7IGxlZnQgfSkgPT5cbiAgICBsZWZ0ICYmIHtcbiAgICAgIGdyaWRDb2x1bW5TdGFydDogbGVmdFxuICAgIH0sXG4gICh7IHRvcCB9KSA9PlxuICAgIHRvcCAmJiB7XG4gICAgICBncmlkUm93U3RhcnQ6IHRvcFxuICAgIH0sXG4gICh7IGFyZWEgfSkgPT5cbiAgICBhcmVhICYmIHtcbiAgICAgIGdyaWRBcmVhOiBhcmVhXG4gICAgfSxcbiAgKHsgbWlkZGxlIH0pID0+XG4gICAgbWlkZGxlICYmIHtcbiAgICAgIGRpc3BsYXk6ICdpbmxpbmUtZmxleCcsXG4gICAgICBmbGV4RmxvdzogJ2NvbHVtbiB3cmFwJyxcbiAgICAgIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgICAgIGp1c3RpZnlTZWxmOiAnc3RyZXRjaCdcbiAgICB9LFxuICAoeyBjZW50ZXIgfSkgPT5cbiAgICBjZW50ZXIgJiYge1xuICAgICAgdGV4dEFsaWduOiAnY2VudGVyJ1xuICAgIH1cbilcbkdyaWRJdGVtLmRpc3BsYXlOYW1lID0gJ0dyaWRJdGVtJ1xuXG5leHBvcnQgZGVmYXVsdCBHcmlkSXRlbVxuIl19 */");
68
- GridItem.displayName = 'GridItem';
67
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9HcmlkL0dyaWRJdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QmlCIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9HcmlkL0dyaWRJdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuXG5leHBvcnQgdHlwZSBHcmlkSXRlbVByb3BzID0ge1xuICAvKiogQWxpZ25zIGl0ZW0gYWxvbmcgdGhlIGNvbHVtbiBheGlzIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9hbGlnbi1zZWxmICovXG4gIGFsaWduU2VsZj86ICdzdGFydCcgfCAnY2VudGVyJyB8ICdlbmQnIHwgJ3N0cmV0Y2gnXG4gIC8qKiBwbGFjZXMgaXRlbSBpbiBhIHNwZWNpZmljIGFyZWEgb2YgdGhlIGdyaWQgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtYXJlYSAqL1xuICBhcmVhPzogc3RyaW5nXG4gIC8qKiBDZW50ZXIgY29udGVudCBob3Jpem9udGFsbHkgKi9cbiAgY2VudGVyPzogYm9vbGVhblxuICBjbGFzc05hbWU/OiBzdHJpbmdcbiAgLyoqIE51bWJlciBvZiBjb2x1bW5zIGl0ZW0gd2lsbCBzcGFuIGh0dHBzOi8vZGV2ZWxvcGVyLm1vemlsbGEub3JnL2VuLVVTL2RvY3MvV2ViL0NTUy9ncmlkLWNvbHVtbi1lbmQgKi9cbiAgY29sV2lkdGg/OiBudW1iZXJcbiAgLyoqIEFsaWducyBpdGVtIGFsb25nIHRoZSByb3cgYXhpcyBodHRwczovL2RldmVsb3Blci5tb3ppbGxhLm9yZy9lbi1VUy9kb2NzL1dlYi9DU1MvanVzdGlmeS1zZWxmICovXG4gIGp1c3RpZnlTZWxmPzogJ3N0YXJ0JyB8ICdjZW50ZXInIHwgJ2VuZCcgfCAnc3RyZXRjaCdcbiAgLyoqIFdoZXJlIGluIHRoZSBncmlkIGNvbHVtbiB0aGUgaXRlbSBzaG91bGQgc3RhcnQgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtY29sdW1uLXN0YXJ0ICovXG4gIGxlZnQ/OiBudW1iZXIgfCBzdHJpbmdcbiAgLyoqIENlbnRlciBjb250ZW50IHZlcnRpY2FsbHkgKi9cbiAgbWlkZGxlPzogYm9vbGVhblxuICAvKiogTnVtYmVyIG9mIHJvd3MgaXRlbSB3aWxsIHNwYW4gaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtcm93LWVuZCAqL1xuICByb3dIZWlnaHQ/OiBudW1iZXJcbiAgLyoqIFdoZXJlIGluIHRoZSBncmlkIHJvdyB0aGUgaXRlbSBzaG91bGQgc3RhcnQgaHR0cHM6Ly9kZXZlbG9wZXIubW96aWxsYS5vcmcvZW4tVVMvZG9jcy9XZWIvQ1NTL2dyaWQtcm93LXN0YXJ0ICovXG4gIHRvcD86IG51bWJlciB8IHN0cmluZ1xufVxuXG5jb25zdCBHcmlkSXRlbSA9IHN0eWxlZCgnZGl2Jyk8R3JpZEl0ZW1Qcm9wcz4oXG4gICh7IHJvd0hlaWdodCA9IDEsIGNvbFdpZHRoID0gMSB9KSA9PiAoe1xuICAgIG1pbldpZHRoOiAwLFxuICAgIGdyaWRDb2x1bW5FbmQ6IGBzcGFuICR7Y29sV2lkdGh9YCxcbiAgICBncmlkUm93RW5kOiBgc3BhbiAke3Jvd0hlaWdodH1gXG4gIH0pLFxuICAoeyBhbGlnblNlbGYgfSkgPT5cbiAgICBhbGlnblNlbGYgJiYge1xuICAgICAgYWxpZ25TZWxmXG4gICAgfSxcbiAgKHsganVzdGlmeVNlbGYgfSkgPT5cbiAgICBqdXN0aWZ5U2VsZiAmJiB7XG4gICAgICBqdXN0aWZ5U2VsZlxuICAgIH0sXG4gICh7IGxlZnQgfSkgPT5cbiAgICBsZWZ0ICYmIHtcbiAgICAgIGdyaWRDb2x1bW5TdGFydDogbGVmdFxuICAgIH0sXG4gICh7IHRvcCB9KSA9PlxuICAgIHRvcCAmJiB7XG4gICAgICBncmlkUm93U3RhcnQ6IHRvcFxuICAgIH0sXG4gICh7IGFyZWEgfSkgPT5cbiAgICBhcmVhICYmIHtcbiAgICAgIGdyaWRBcmVhOiBhcmVhXG4gICAgfSxcbiAgKHsgbWlkZGxlIH0pID0+XG4gICAgbWlkZGxlICYmIHtcbiAgICAgIGRpc3BsYXk6ICdpbmxpbmUtZmxleCcsXG4gICAgICBmbGV4RmxvdzogJ2NvbHVtbiB3cmFwJyxcbiAgICAgIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgICAgIGp1c3RpZnlTZWxmOiAnc3RyZXRjaCdcbiAgICB9LFxuICAoeyBjZW50ZXIgfSkgPT5cbiAgICBjZW50ZXIgJiYge1xuICAgICAgdGV4dEFsaWduOiAnY2VudGVyJ1xuICAgIH1cbilcblxuZXhwb3J0IGRlZmF1bHQgR3JpZEl0ZW1cbiJdfQ== */");
69
68
  var _default = GridItem;
70
69
  exports["default"] = _default;
@@ -223,7 +223,7 @@ var InputComponent = ( /*#__PURE__*/0, _base["default"])('input', process.env.NO
223
223
  margin: 0
224
224
  }
225
225
  };
226
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Input.Root)], process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAsHuB","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\nInlineInputComponent.displayName = 'InlineInputComponent'\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
226
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Input.Root)], process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAsHuB","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
227
227
  var TextAreaComponent = ( /*#__PURE__*/0, _base["default"])('textarea', process.env.NODE_ENV === "production" ? {
228
228
  target: "e1kldv1q4"
229
229
  } : {
@@ -232,7 +232,7 @@ var TextAreaComponent = ( /*#__PURE__*/0, _base["default"])('textarea', process.
232
232
  })([baseStyles, secondaryVariantStyles, invalidStyles, disabledStyles, {
233
233
  display: 'block',
234
234
  minHeight: '6em'
235
- }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Input.Root)], process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAwK0B","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\nInlineInputComponent.displayName = 'InlineInputComponent'\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
235
+ }, (0, _ThemeProvider.getOverrides)(_ThemeProvider.Overridable.Input.Root)], process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAwK0B","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
236
236
  var InlineInputComponentWrapper = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
237
237
  target: "e1kldv1q3"
238
238
  } : {
@@ -246,7 +246,7 @@ var InlineInputComponentWrapper = ( /*#__PURE__*/0, _base["default"])('span', pr
246
246
  height: INLINE_HEIGHT,
247
247
  justifyContent: 'center',
248
248
  position: 'relative'
249
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAoLoC","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\nInlineInputComponent.displayName = 'InlineInputComponent'\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */"); // This component needs to mirror the styles of the input pretty closely for
249
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAoLoC","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */"); // This component needs to mirror the styles of the input pretty closely for
250
250
  // anything that might change its width
251
251
 
252
252
  var InlineInputComponentSizer = ( /*#__PURE__*/0, _base["default"])('span', process.env.NODE_ENV === "production" ? {
@@ -269,7 +269,7 @@ var InlineInputComponentSizer = ( /*#__PURE__*/0, _base["default"])('span', proc
269
269
  minWidth: '34px',
270
270
  border: focus ? 'solid 1px transparent' : 'none'
271
271
  };
272
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAgMkC","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\nInlineInputComponent.displayName = 'InlineInputComponent'\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
272
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAgMkC","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
273
273
  var InlineInputComponentUnderlineWrapper = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
274
274
  target: "e1kldv1q1"
275
275
  } : {
@@ -281,7 +281,7 @@ var InlineInputComponentUnderlineWrapper = ( /*#__PURE__*/0, _base["default"])('
281
281
  position: 'absolute',
282
282
  top: 0,
283
283
  width: '100%'
284
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AA+M6C","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\nInlineInputComponent.displayName = 'InlineInputComponent'\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
284
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AA+M6C","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
285
285
  var InlineInputComponentUnderline = ( /*#__PURE__*/0, _base["default"])('div', process.env.NODE_ENV === "production" ? {
286
286
  target: "e1kldv1q0"
287
287
  } : {
@@ -306,7 +306,7 @@ var InlineInputComponentUnderline = ( /*#__PURE__*/0, _base["default"])('div', p
306
306
  return hidden && {
307
307
  display: 'none'
308
308
  };
309
- }, disabledStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAuN6C","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\nInlineInputComponent.displayName = 'InlineInputComponent'\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
309
+ }, disabledStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Input/Input.tsx"],"names":[],"mappings":"AAuN6C","file":"../../../src/Input/Input.tsx","sourcesContent":["import styled, { CSSObject } from '@emotion/styled'\nimport clamp from 'lodash.clamp'\nimport isNumber from 'lodash.isnumber'\nimport React, { PureComponent, useState } from 'react'\nimport type { InputHTMLAttributes, TextareaHTMLAttributes } from 'react'\nimport { getOverrides, Overridable } from '../ThemeProvider'\nimport type { Theme } from '../ThemeProvider'\n\ntype Variant =\n  | 'primary'\n  | 'secondary'\n  | {\n      borderBottomColor: string\n      color: string\n      focusBorderColor: string\n      placeholderColor: string\n    }\n\ntype StyleFunc = (props: {\n  theme: Theme\n  invalid?: boolean\n  inline?: boolean\n  disabled?: boolean\n  variant?: Variant\n}) => CSSObject\n\nconst baseStyles: StyleFunc = ({ theme }) => ({\n  fontSize: theme.fontSize[1],\n  lineHeight: theme.lineHeight[5],\n  backgroundColor: theme.palette.neutral[0],\n  borderRadius: theme.radius[2],\n  borderWidth: theme.borderWidth[1],\n  borderStyle: 'solid',\n  borderColor: theme.palette.neutral[4],\n  color: theme.palette.neutral[11],\n  display: 'inline-block',\n  width: 'auto',\n  paddingTop: theme.space[2],\n  paddingBottom: theme.space[2],\n  paddingLeft: theme.space[3],\n  paddingRight: theme.space[3],\n  boxShadow: 'none',\n  ':focus': {\n    outline: 'none',\n    borderColor: theme.palette.neutral[7],\n    boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.primary[2]}`\n  },\n  '::placeholder': {\n    color: theme.palette.neutral[9]\n  }\n})\n\nconst invalidStyles: StyleFunc = ({ theme, invalid = false, inline }) =>\n  invalid\n    ? {\n        outline: 'none',\n        background: inline ? 'transparent' : theme.palette.error[0],\n        borderColor: theme.palette.error[1]\n      }\n    : {}\n\nconst disabledStyles: StyleFunc = ({\n  theme,\n  disabled = false,\n  inline = false\n}) =>\n  disabled\n    ? {\n        color: theme.palette.neutral[9],\n        backgroundColor: inline ? undefined : theme.palette.neutral[2],\n        cursor: 'not-allowed',\n        pointerEvents: 'none' as const,\n        borderBottomColor: inline ? theme.palette.neutral[7] : undefined,\n        '::placeholder': {\n          color: theme.palette.neutral[9]\n        }\n      }\n    : {}\n\nconst secondaryVariantStyles: StyleFunc = ({ theme, variant = 'primary' }) =>\n  variant === 'secondary'\n    ? {\n        ':focus': {\n          boxShadow: `0px 0px 0px ${theme.borderWidth[2]} ${theme.palette.secondary[2]}`\n        }\n      }\n    : {}\n\ntype ComponentProps = {\n  disabled?: boolean\n  'data-instrumentation'?: string\n  invalid?: boolean\n  variant?: Variant\n  type: InputTypes\n}\n\nconst INLINE_HEIGHT = 27 // match tagger and inline select\n\nconst variants = {\n  primary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.primary[3],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.primary[3],\n    placeholderColor: theme.palette.primary[4]\n  }),\n  secondary: (theme: Theme) => ({\n    borderBottomColor: theme.palette.secondary[2],\n    color: theme.palette.neutral[11],\n    focusBorderColor: theme.palette.secondary[3],\n    placeholderColor: theme.palette.secondary[5]\n  })\n}\n\nconst getVariantStyles = (theme: Theme, variant: Variant) =>\n  typeof variant === 'string' ? variants[variant](theme) : variant\n\nconst INLINE_PADDING = '0.15rem 0.75rem'\n\nconst InputComponent = styled('input')<ComponentProps & { inline?: boolean }>([\n  baseStyles,\n  secondaryVariantStyles,\n  {\n    height: '2.25rem',\n    width: 'auto',\n    minWidth: '0'\n  },\n  ({ theme, inline = false, variant = 'primary' }) =>\n    inline && {\n      color: getVariantStyles(theme, variant).color,\n      height: INLINE_HEIGHT,\n      left: '0',\n      padding: INLINE_PADDING,\n      position: 'absolute',\n      width: '100%',\n      background: 'transparent',\n      ':not(:focus)': {\n        border: 'none',\n        fontWeight: 700\n      },\n      ':focus': {\n        boxShadow: 'none',\n        borderColor: getVariantStyles(theme, variant).focusBorderColor,\n        '::placeholder': {\n          fontWeight: 400,\n          color: theme.palette.neutral[9]\n        }\n      },\n      '::placeholder': {\n        fontWeight: 400,\n        color: getVariantStyles(theme, variant).placeholderColor\n      }\n    },\n  invalidStyles,\n  disabledStyles,\n  ({ inline = false, type }) =>\n    inline &&\n    type === 'number' && {\n      // Remove browser's number input controls.\n      appearance: 'textfield', // Chrome/Firefox.\n      '::-webkit-inner-spin-button': {\n        // Safari.\n        WebkitAppearance: 'none',\n        margin: 0\n      }\n    },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst TextAreaComponent = styled('textarea')<ComponentProps>([\n  baseStyles,\n  secondaryVariantStyles,\n  invalidStyles,\n  disabledStyles,\n  {\n    display: 'block',\n    minHeight: '6em'\n  },\n  getOverrides(Overridable.Input.Root)\n])\n\nconst InlineInputComponentWrapper = styled('span')({\n  alignContent: 'center',\n  display: 'flex',\n  flex: '0 auto',\n  flexDirection: 'column',\n  height: INLINE_HEIGHT,\n  justifyContent: 'center',\n  position: 'relative'\n})\n\n// This component needs to mirror the styles of the input pretty closely for\n// anything that might change its width\nconst InlineInputComponentSizer = styled('span')<{\n  focus: boolean\n  hasValue: boolean\n}>(({ theme, focus, hasValue }) => ({\n  color: 'transparent',\n  fontWeight: !focus && hasValue ? 700 : 400,\n  fontSize: theme.fontSize[1],\n  height: INLINE_HEIGHT,\n  lineHeight: theme.lineHeight[5],\n  padding: INLINE_PADDING,\n  whiteSpace: 'pre',\n  minWidth: '34px',\n  border: focus ? 'solid 1px transparent' : 'none'\n}))\n\nconst InlineInputComponentUnderlineWrapper = styled('div')({\n  bottom: 1,\n  padding: INLINE_PADDING,\n  position: 'absolute',\n  top: 0,\n  width: '100%'\n})\n\nexport const InlineInputComponentUnderline = styled('div')<{\n  hasValue: boolean\n  hidden?: boolean\n  inline?: boolean\n  invalid?: boolean\n  variant?: Variant\n  disabled?: boolean\n}>(\n  ({ theme, variant = 'primary', hasValue }) => ({\n    borderBottomWidth: 2,\n    borderBottomColor: getVariantStyles(theme, variant).borderBottomColor,\n    borderBottomStyle: hasValue ? 'solid' : 'dotted',\n    height: '100%',\n    width: '100%',\n    minWidth: theme.space[2]\n  }),\n  invalidStyles,\n  ({ hidden = true }) => hidden && { display: 'none' },\n  disabledStyles\n)\n\ntype InlineInputProps = React.InputHTMLAttributes<HTMLInputElement> &\n  ComponentProps & { inline?: boolean }\n\nconst InlineInput = ({\n  forwardRef,\n  invalid,\n  placeholder,\n  type,\n  value,\n  variant,\n  ...props\n}: InlineInputProps & { forwardRef?: React.RefObject<HTMLInputElement> }) => {\n  const [focus, setFocus] = useState(false)\n  // Hide placeholder on empty values\n  const sizerValue =\n    value !== undefined && value !== null && value !== ''\n      ? value\n      : placeholder || ' '\n  return (\n    <InlineInputComponentWrapper\n      onFocus={() => setFocus(true)}\n      onBlur={() => setFocus(false)}\n    >\n      <InlineInputComponentSizer\n        aria-hidden=\"true\"\n        focus={focus}\n        hasValue={!!value}\n      >\n        {sizerValue}\n      </InlineInputComponentSizer>\n      <InlineInputComponentUnderlineWrapper>\n        <InlineInputComponentUnderline\n          inline\n          invalid={invalid}\n          hidden={focus}\n          variant={variant}\n          hasValue={!!value}\n          disabled={props.disabled}\n        />\n      </InlineInputComponentUnderlineWrapper>\n      <InputComponent\n        {...props}\n        invalid={invalid}\n        placeholder={placeholder}\n        ref={forwardRef}\n        type={type}\n        value={value !== undefined && type === 'number' ? String(value) : value} // Clears leading zeros; https://github.com/facebook/react/issues/9402\n        variant={variant}\n        inline\n      />\n    </InlineInputComponentWrapper>\n  )\n}\n\nexport const InlineInputComponent = React.forwardRef(\n  (props: InlineInputProps, ref: React.RefObject<HTMLInputElement>) => (\n    <InlineInput {...props} forwardRef={ref} />\n  )\n)\n\ntype NumberTypes = 'number'\ntype TextAreaType = 'textarea'\ntype StringTypes =\n  | 'url'\n  | 'datetime-local'\n  | 'email'\n  | 'password'\n  | 'text'\n  | TextAreaType\nexport type InputTypes = NumberTypes | StringTypes\n/**\n * This uses a generic plus conditional types to adjust prop types based on the type prop.\n *\n * For more info on generics, please read this:\n * https://dev.to/busypeoples/-notes-on-typescript-react-and-generics-35c9\n *\n * For more info on conditional types, please read this:\n * https://artsy.github.io/blog/2018/11/21/conditional-types-in-typescript/\n */\nexport type InputProps<T extends InputTypes = 'text'> = {\n  className?: string\n  disabled?: boolean\n  'data-instrumentation'?: string\n  id?: string\n  inline?: boolean\n  inputRef?: any // TODO: figure out how to type this correctly\n  invalid?: boolean\n  max?: number\n  min?: number\n  name: string\n  onBlur?: (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => void\n  onChange: (arg0: { name: string; value?: InputValue<T> }) => void\n  placeholder?: string\n  type?: T\n  value: InputValue<T>\n  variant?: Variant\n} & Omit<InputHTMLAttributes<HTMLInputElement>, 'onChange'> &\n  Omit<TextareaHTMLAttributes<HTMLTextAreaElement>, 'onChange'>\n\ntype InputValue<T extends InputTypes> = T extends NumberTypes ? number : string\n\nclass Input<T extends InputTypes = 'text'> extends PureComponent<\n  InputProps<T>\n> {\n  _sanitizeNumber = (value: string): number | string => {\n    const { min, max } = this.props\n    const next = value === '' ? '' : parseFloat(value) || 0\n    if (isNumber(next)) {\n      return clamp(next, min || -Infinity, max || +Infinity)\n    } else {\n      return next\n    }\n  }\n\n  _onBlur = (\n    event: React.FocusEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    if (type === 'number') {\n      const { name } = event.currentTarget\n      const value = this._sanitizeNumber(event.currentTarget?.value || '')\n      this.props.onChange({\n        name,\n        value: this._isInputValue(value) ? value : undefined\n      })\n    }\n    if (this.props.onBlur) {\n      this.props.onBlur(event)\n    }\n  }\n\n  _isInputValue = (value: string | number): value is InputValue<T> =>\n    (this.props.type === 'number' && isNumber(value)) ||\n    (this.props.type !== 'number' && !isNumber(value))\n\n  _onChange = (\n    event: React.ChangeEvent<HTMLTextAreaElement | HTMLInputElement>\n  ) => {\n    const { type } = this.props\n    const { name } = event.target\n\n    const value =\n      type === 'number' ? parseFloat(event.target.value) : event.target.value\n\n    this.props.onChange({\n      name,\n      value: this._isInputValue(value) ? value : undefined\n    })\n  }\n\n  getComponent = () => {\n    if (this.props.type === 'textarea') {\n      return TextAreaComponent\n    }\n    if (this.props.inline) {\n      return InlineInputComponent\n    }\n    return InputComponent\n  }\n\n  render() {\n    const {\n      className,\n      disabled = false,\n      id,\n      inputRef,\n      invalid = false,\n      name,\n      placeholder = '',\n      type = 'text',\n      value,\n      'data-instrumentation': dataInstrumentation = 'input',\n      ...props\n    } = this.props\n\n    // workaround for browsers that do not natively support datetime input fields\n    const newPlaceholder =\n      type === 'datetime-local' && !placeholder\n        ? 'YYYY-MM-DDTHH:mm'\n        : placeholder\n\n    const Component = this.getComponent()\n\n    return (\n      <Component\n        {...props}\n        className={className}\n        disabled={disabled}\n        id={id || name}\n        ref={inputRef}\n        invalid={invalid}\n        name={name}\n        data-instrumentation={dataInstrumentation}\n        onBlur={this._onBlur}\n        onChange={this._onChange}\n        placeholder={newPlaceholder}\n        type={type}\n        value={value}\n      />\n    )\n  }\n}\n\nexport default Input\n"]} */");
310
310
  exports.InlineInputComponentUnderline = InlineInputComponentUnderline;
311
311
 
312
312
  var InlineInput = function InlineInput(_ref10) {
@@ -376,7 +376,6 @@ var InlineInputComponent = /*#__PURE__*/_react["default"].forwardRef(function (p
376
376
  });
377
377
 
378
378
  exports.InlineInputComponent = InlineInputComponent;
379
- InlineInputComponent.displayName = 'InlineInputComponent';
380
379
 
381
380
  var Input = /*#__PURE__*/function (_PureComponent) {
382
381
  _inherits(Input, _PureComponent);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "td-stylekit",
3
- "version": "28.22.1",
3
+ "version": "28.22.2",
4
4
  "main": "dist/es/index.js",
5
5
  "module": "dist/es/index.js",
6
6
  "types": "dist/es/index.d.ts",