td-stylekit 30.4.1 → 30.4.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
+ ## [30.4.2](https://github.com/treasure-data/td-stylekit/compare/v30.4.1...v30.4.2) (2025-01-27)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * **CON-17736:** Do not allow nested Icons in Buttons to swallow up events ([#1622](https://github.com/treasure-data/td-stylekit/issues/1622)) ([c30cfa0](https://github.com/treasure-data/td-stylekit/commit/c30cfa04c205fa80b890290e99ab89723c77cc3e))
7
+
1
8
  ## [30.4.1](https://github.com/treasure-data/td-stylekit/compare/v30.4.0...v30.4.1) (2024-11-28)
2
9
 
3
10
 
@@ -167,7 +167,12 @@ function (_ref6) {
167
167
  height: 'auto',
168
168
  padding: 0,
169
169
  minHeight: small ? (0, _utils.multiply)(theme.space[2], 2.5) : (0, _utils.multiply)(theme.space[3], 3),
170
- minWidth: small ? (0, _utils.multiply)(theme.space[2], 2.5) : (0, _utils.multiply)(theme.space[3], 3)
170
+ minWidth: small ? (0, _utils.multiply)(theme.space[2], 2.5) : (0, _utils.multiply)(theme.space[3], 3),
171
+ 'svg:first-of-type': {
172
+ // prevents nested icons from swallowing click events
173
+ // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/
174
+ pointerEvents: 'none'
175
+ }
171
176
  };
172
177
  },
173
178
  // circle
@@ -394,7 +399,7 @@ var StyledButton = /*#__PURE__*/(0, _base["default"])(UnstyledButton, process.en
394
399
  } : {
395
400
  target: "e1tp8vho0",
396
401
  label: "StyledButton"
397
- })(styles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Button/Button.tsx"],"names":[],"mappings":"AA4fqB","file":"../../../src/Button/Button.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  RefObject,\n  ButtonHTMLAttributes,\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<PropsWithChildren<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?: 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?: 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: 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"]} */");
402
+ })(styles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Button/Button.tsx"],"names":[],"mappings":"AAigBqB","file":"../../../src/Button/Button.tsx","sourcesContent":["import {\n  PropsWithChildren,\n  RefObject,\n  ButtonHTMLAttributes,\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      'svg:first-of-type': {\n        // prevents nested icons from swallowing click events\n        // https://css-tricks.com/slightly-careful-sub-elements-clickable-things/\n        pointerEvents: 'none'\n      }\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<PropsWithChildren<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?: 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?: 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: 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"]} */");
398
403
  // eslint-disable-next-line react/display-name
399
404
  var Button = exports.Button = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
400
405
  return (0, _jsxRuntime.jsx)(StyledButton, _objectSpread({
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "td-stylekit",
3
- "version": "30.4.1",
3
+ "version": "30.4.2",
4
4
  "main": "dist/es/index.js",
5
5
  "module": "dist/es/index.js",
6
6
  "types": "dist/es/index.d.ts",