@commercetools-uikit/secondary-button 19.25.1 → 20.0.0
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/dist/commercetools-uikit-secondary-button.cjs.dev.js +3 -19
- package/dist/commercetools-uikit-secondary-button.cjs.prod.js +1 -3
- package/dist/commercetools-uikit-secondary-button.esm.js +3 -18
- package/dist/declarations/src/export-types.d.ts +1 -0
- package/dist/declarations/src/secondary-button.d.ts +4 -3
- package/package.json +11 -12
|
@@ -11,7 +11,6 @@ var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/ob
|
|
|
11
11
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
12
12
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
13
13
|
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
14
|
-
var _pt = require('prop-types');
|
|
15
14
|
var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
|
|
16
15
|
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
17
16
|
var react$1 = require('react');
|
|
@@ -32,7 +31,6 @@ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachIns
|
|
|
32
31
|
var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
|
|
33
32
|
var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
|
|
34
33
|
var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
|
|
35
|
-
var _pt__default = /*#__PURE__*/_interopDefault(_pt);
|
|
36
34
|
var _indexOfInstanceProperty__default = /*#__PURE__*/_interopDefault(_indexOfInstanceProperty);
|
|
37
35
|
var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
|
|
38
36
|
var Inline__default = /*#__PURE__*/_interopDefault(Inline);
|
|
@@ -114,7 +112,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
114
112
|
styles: "display:flex;align-items:center;justify-content:center"
|
|
115
113
|
} : {
|
|
116
114
|
name: "17kup4k-PositionedIcon",
|
|
117
|
-
styles: "display:flex;align-items:center;justify-content:center;label:PositionedIcon;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AA4Ic","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */",
|
|
115
|
+
styles: "display:flex;align-items:center;justify-content:center;label:PositionedIcon;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AA6Ic","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { type TIconProps } from '@commercetools-uikit/design-system';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement<TIconProps>;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement<TIconProps>;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement<TIconProps>;\n  color: TIconProps['color'];\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconLeft\n              )!\n            }\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconRight\n              )!\n            }\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */",
|
|
118
116
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
119
117
|
};
|
|
120
118
|
const PositionedIcon = _ref2 => {
|
|
@@ -157,7 +155,7 @@ const SecondaryButton = _ref3 => {
|
|
|
157
155
|
} : {});
|
|
158
156
|
process.env.NODE_ENV !== "production" ? utils.warning(!(theme !== 'default' && !isToggleButton), `Invalid prop \`theme\` supplied to \`SecondaryButton\`. Only toggle buttons may have a theme.`) : void 0;
|
|
159
157
|
utils.useWarning(!Boolean(_indexOfInstanceProperty__default["default"](_context = _Object$keys__default["default"](sizeMapping)).call(_context, size) > -1), `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${sizeMapping[size]}' Please update that value when using this component`);
|
|
160
|
-
const containerStyles = [/*#__PURE__*/react.css("display:flex;align-items:center;padding:0 ", designSystem.designTokens.spacing30, ";height:", designSystem.designTokens.heightForButtonAs40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAgMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), /*#__PURE__*/react.css("display:inline-flex;background-color:", designSystem.designTokens.colorSurface, ";border:1px solid ", designSystem.designTokens.colorNeutral, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow0, ";color:", designSystem.designTokens.colorSolid, ";transition:background-color ", designSystem.designTokens.transitionLinear80Ms, ",box-shadow ", designSystem.designTokens.transitionEaseinout150Ms, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAsMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(theme), getStateStyles(props.isDisabled, isActive, tone), getSizeStyles(size), getToneStyles(tone, props.isDisabled, isActive)];
|
|
158
|
+
const containerStyles = [/*#__PURE__*/react.css("display:flex;align-items:center;padding:0 ", designSystem.designTokens.spacing30, ";height:", designSystem.designTokens.heightForButtonAs40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAiMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { type TIconProps } from '@commercetools-uikit/design-system';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement<TIconProps>;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement<TIconProps>;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement<TIconProps>;\n  color: TIconProps['color'];\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconLeft\n              )!\n            }\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconRight\n              )!\n            }\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), /*#__PURE__*/react.css("display:inline-flex;background-color:", designSystem.designTokens.colorSurface, ";border:1px solid ", designSystem.designTokens.colorNeutral, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow0, ";color:", designSystem.designTokens.colorSolid, ";transition:background-color ", designSystem.designTokens.transitionLinear80Ms, ",box-shadow ", designSystem.designTokens.transitionEaseinout150Ms, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAuMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { type TIconProps } from '@commercetools-uikit/design-system';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement<TIconProps>;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement<TIconProps>;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement<TIconProps>;\n  color: TIconProps['color'];\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconLeft\n              )!\n            }\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconRight\n              )!\n            }\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(theme), getStateStyles(props.isDisabled, isActive, tone), getSizeStyles(size), getToneStyles(tone, props.isDisabled, isActive)];
|
|
161
159
|
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
162
160
|
as: shouldUseLinkTag ? reactRouterDom.Link : props.as,
|
|
163
161
|
type: type,
|
|
@@ -197,25 +195,11 @@ const SecondaryButton = _ref3 => {
|
|
|
197
195
|
})
|
|
198
196
|
});
|
|
199
197
|
};
|
|
200
|
-
SecondaryButton.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
201
|
-
as: _pt__default["default"].any,
|
|
202
|
-
type: _pt__default["default"].oneOf(['button', 'reset', 'submit']),
|
|
203
|
-
label: _pt__default["default"].string.isRequired,
|
|
204
|
-
iconLeft: _pt__default["default"].element,
|
|
205
|
-
iconRight: _pt__default["default"].element,
|
|
206
|
-
isToggleButton: _pt__default["default"].bool,
|
|
207
|
-
isToggled: _pt__default["default"].bool,
|
|
208
|
-
isDisabled: _pt__default["default"].bool,
|
|
209
|
-
onClick: _pt__default["default"].func,
|
|
210
|
-
size: _pt__default["default"].oneOfType([_pt__default["default"].oneOf(['small', 'medium', 'big']), _pt__default["default"].oneOf(['10', '20'])]),
|
|
211
|
-
theme: _pt__default["default"].oneOf(['default', 'info']),
|
|
212
|
-
tone: _pt__default["default"].oneOf(['secondary', 'info'])
|
|
213
|
-
} : {};
|
|
214
198
|
SecondaryButton.displayName = 'SecondaryButton';
|
|
215
199
|
var SecondaryButton$1 = SecondaryButton;
|
|
216
200
|
|
|
217
201
|
// NOTE: This string will be replaced on build time with the package version.
|
|
218
|
-
var version = "
|
|
202
|
+
var version = "20.0.0";
|
|
219
203
|
|
|
220
204
|
exports["default"] = SecondaryButton$1;
|
|
221
205
|
exports.version = version;
|
|
@@ -11,7 +11,6 @@ var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/ob
|
|
|
11
11
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
12
12
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
13
13
|
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
14
|
-
require('prop-types');
|
|
15
14
|
var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
|
|
16
15
|
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
17
16
|
var react$1 = require('react');
|
|
@@ -189,12 +188,11 @@ const SecondaryButton = _ref3 => {
|
|
|
189
188
|
})
|
|
190
189
|
});
|
|
191
190
|
};
|
|
192
|
-
SecondaryButton.propTypes = {};
|
|
193
191
|
SecondaryButton.displayName = 'SecondaryButton';
|
|
194
192
|
var SecondaryButton$1 = SecondaryButton;
|
|
195
193
|
|
|
196
194
|
// NOTE: This string will be replaced on build time with the package version.
|
|
197
|
-
var version = "
|
|
195
|
+
var version = "20.0.0";
|
|
198
196
|
|
|
199
197
|
exports["default"] = SecondaryButton$1;
|
|
200
198
|
exports.version = version;
|
|
@@ -7,7 +7,6 @@ import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/obje
|
|
|
7
7
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
8
8
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
9
9
|
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
10
|
-
import _pt from 'prop-types';
|
|
11
10
|
import _indexOfInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/index-of';
|
|
12
11
|
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
13
12
|
import { cloneElement } from 'react';
|
|
@@ -95,7 +94,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
95
94
|
styles: "display:flex;align-items:center;justify-content:center"
|
|
96
95
|
} : {
|
|
97
96
|
name: "17kup4k-PositionedIcon",
|
|
98
|
-
styles: "display:flex;align-items:center;justify-content:center;label:PositionedIcon;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AA4Ic","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */",
|
|
97
|
+
styles: "display:flex;align-items:center;justify-content:center;label:PositionedIcon;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AA6Ic","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { type TIconProps } from '@commercetools-uikit/design-system';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement<TIconProps>;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement<TIconProps>;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement<TIconProps>;\n  color: TIconProps['color'];\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconLeft\n              )!\n            }\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconRight\n              )!\n            }\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */",
|
|
99
98
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
100
99
|
};
|
|
101
100
|
const PositionedIcon = _ref2 => {
|
|
@@ -138,7 +137,7 @@ const SecondaryButton = _ref3 => {
|
|
|
138
137
|
} : {});
|
|
139
138
|
process.env.NODE_ENV !== "production" ? warning(!(theme !== 'default' && !isToggleButton), `Invalid prop \`theme\` supplied to \`SecondaryButton\`. Only toggle buttons may have a theme.`) : void 0;
|
|
140
139
|
useWarning(!Boolean(_indexOfInstanceProperty(_context = _Object$keys(sizeMapping)).call(_context, size) > -1), `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${sizeMapping[size]}' Please update that value when using this component`);
|
|
141
|
-
const containerStyles = [/*#__PURE__*/css("display:flex;align-items:center;padding:0 ", designTokens.spacing30, ";height:", designTokens.heightForButtonAs40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAgMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), /*#__PURE__*/css("display:inline-flex;background-color:", designTokens.colorSurface, ";border:1px solid ", designTokens.colorNeutral, ";border-radius:", designTokens.borderRadius4, ";box-shadow:", designTokens.shadow0, ";color:", designTokens.colorSolid, ";transition:background-color ", designTokens.transitionLinear80Ms, ",box-shadow ", designTokens.transitionEaseinout150Ms, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAsMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(theme), getStateStyles(props.isDisabled, isActive, tone), getSizeStyles(size), getToneStyles(tone, props.isDisabled, isActive)];
|
|
140
|
+
const containerStyles = [/*#__PURE__*/css("display:flex;align-items:center;padding:0 ", designTokens.spacing30, ";height:", designTokens.heightForButtonAs40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAiMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { type TIconProps } from '@commercetools-uikit/design-system';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement<TIconProps>;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement<TIconProps>;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement<TIconProps>;\n  color: TIconProps['color'];\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconLeft\n              )!\n            }\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconRight\n              )!\n            }\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), /*#__PURE__*/css("display:inline-flex;background-color:", designTokens.colorSurface, ";border:1px solid ", designTokens.colorNeutral, ";border-radius:", designTokens.borderRadius4, ";box-shadow:", designTokens.shadow0, ";color:", designTokens.colorSolid, ";transition:background-color ", designTokens.transitionLinear80Ms, ",box-shadow ", designTokens.transitionEaseinout150Ms, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAuMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport { type TIconProps } from '@commercetools-uikit/design-system';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement<TIconProps>;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement<TIconProps>;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement<TIconProps>;\n  color: TIconProps['color'];\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconLeft\n              )!\n            }\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={\n              getIconColor(\n                {\n                  type,\n                  theme,\n                  tone,\n                  size,\n                  isToggleButton,\n                  ...props,\n                },\n                props.iconRight\n              )!\n            }\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(theme), getStateStyles(props.isDisabled, isActive, tone), getSizeStyles(size), getToneStyles(tone, props.isDisabled, isActive)];
|
|
142
141
|
return jsx(AccessibleButton, {
|
|
143
142
|
as: shouldUseLinkTag ? Link : props.as,
|
|
144
143
|
type: type,
|
|
@@ -178,24 +177,10 @@ const SecondaryButton = _ref3 => {
|
|
|
178
177
|
})
|
|
179
178
|
});
|
|
180
179
|
};
|
|
181
|
-
SecondaryButton.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
182
|
-
as: _pt.any,
|
|
183
|
-
type: _pt.oneOf(['button', 'reset', 'submit']),
|
|
184
|
-
label: _pt.string.isRequired,
|
|
185
|
-
iconLeft: _pt.element,
|
|
186
|
-
iconRight: _pt.element,
|
|
187
|
-
isToggleButton: _pt.bool,
|
|
188
|
-
isToggled: _pt.bool,
|
|
189
|
-
isDisabled: _pt.bool,
|
|
190
|
-
onClick: _pt.func,
|
|
191
|
-
size: _pt.oneOfType([_pt.oneOf(['small', 'medium', 'big']), _pt.oneOf(['10', '20'])]),
|
|
192
|
-
theme: _pt.oneOf(['default', 'info']),
|
|
193
|
-
tone: _pt.oneOf(['secondary', 'info'])
|
|
194
|
-
} : {};
|
|
195
180
|
SecondaryButton.displayName = 'SecondaryButton';
|
|
196
181
|
var SecondaryButton$1 = SecondaryButton;
|
|
197
182
|
|
|
198
183
|
// NOTE: This string will be replaced on build time with the package version.
|
|
199
|
-
var version = "
|
|
184
|
+
var version = "20.0.0";
|
|
200
185
|
|
|
201
186
|
export { SecondaryButton$1 as default, version };
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { ReactElement, KeyboardEvent, MouseEvent, ElementType, ComponentPropsWithRef } from 'react';
|
|
2
|
+
import { type TIconProps } from '@commercetools-uikit/design-system';
|
|
2
3
|
/**
|
|
3
4
|
* @deprecated Use sizes from `TSizes` instead.
|
|
4
5
|
*/
|
|
@@ -26,11 +27,11 @@ export type TSecondaryButtonProps<TStringOrComponent extends ElementType = 'butt
|
|
|
26
27
|
/**
|
|
27
28
|
* The left icon displayed within the button.
|
|
28
29
|
*/
|
|
29
|
-
iconLeft?: ReactElement
|
|
30
|
+
iconLeft?: ReactElement<TIconProps>;
|
|
30
31
|
/**
|
|
31
32
|
* The righr icon displayed within the button.
|
|
32
33
|
*/
|
|
33
|
-
iconRight?: ReactElement
|
|
34
|
+
iconRight?: ReactElement<TIconProps>;
|
|
34
35
|
/**
|
|
35
36
|
* If this is active, it means the button will persist in an "active" state when toggled (see `isToggled`), and back to normal state when untoggled
|
|
36
37
|
*/
|
|
@@ -69,7 +70,7 @@ export type TSecondaryButtonProps<TStringOrComponent extends ElementType = 'butt
|
|
|
69
70
|
*/ ComponentPropsWithRef<TStringOrComponent>;
|
|
70
71
|
export declare const getIconColor: (props: Pick<TSecondaryButtonProps, "isToggleButton" | "isToggled" | "theme" | "isDisabled"> & {
|
|
71
72
|
isActive?: boolean;
|
|
72
|
-
}, icon: TSecondaryButtonProps["iconLeft"] | TSecondaryButtonProps["iconRight"]) =>
|
|
73
|
+
}, icon: TSecondaryButtonProps["iconLeft"] | TSecondaryButtonProps["iconRight"]) => "solid" | "primary" | "info" | "neutral60" | "surface" | "primary40" | "warning" | "error" | "success" | undefined;
|
|
73
74
|
export declare const SecondaryButton: {
|
|
74
75
|
<TStringOrComponent extends ElementType = "button">({ type, theme, tone, size, isToggleButton, ...props }: TSecondaryButtonProps<TStringOrComponent>): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
75
76
|
displayName: string;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/secondary-button",
|
|
3
3
|
"description": "Secondary buttons are used in combination with a PrimaryButton and represent the secondary action.",
|
|
4
|
-
"version": "
|
|
4
|
+
"version": "20.0.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,24 +21,23 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.20.13",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
24
|
-
"@commercetools-uikit/accessible-button": "
|
|
25
|
-
"@commercetools-uikit/design-system": "
|
|
26
|
-
"@commercetools-uikit/spacings-inline": "
|
|
27
|
-
"@commercetools-uikit/text": "
|
|
28
|
-
"@commercetools-uikit/utils": "
|
|
24
|
+
"@commercetools-uikit/accessible-button": "20.0.0",
|
|
25
|
+
"@commercetools-uikit/design-system": "20.0.0",
|
|
26
|
+
"@commercetools-uikit/spacings-inline": "20.0.0",
|
|
27
|
+
"@commercetools-uikit/text": "20.0.0",
|
|
28
|
+
"@commercetools-uikit/utils": "20.0.0",
|
|
29
29
|
"@emotion/react": "^11.10.5",
|
|
30
30
|
"@emotion/styled": "^11.10.5",
|
|
31
|
-
"lodash": "4.17.21"
|
|
32
|
-
"prop-types": "15.8.1"
|
|
31
|
+
"lodash": "4.17.21"
|
|
33
32
|
},
|
|
34
33
|
"devDependencies": {
|
|
35
|
-
"react": "
|
|
36
|
-
"react-intl": "^
|
|
34
|
+
"react": "19.0.0",
|
|
35
|
+
"react-intl": "^7.1.4",
|
|
37
36
|
"react-router-dom": "5.3.4"
|
|
38
37
|
},
|
|
39
38
|
"peerDependencies": {
|
|
40
|
-
"react": "
|
|
41
|
-
"react-intl": "
|
|
39
|
+
"react": "19.x",
|
|
40
|
+
"react-intl": "7.x",
|
|
42
41
|
"react-router-dom": "5.x"
|
|
43
42
|
}
|
|
44
43
|
}
|