@commercetools-uikit/secondary-button 19.12.1 → 19.14.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/README.md CHANGED
@@ -23,7 +23,8 @@ import SecondaryButton from '@commercetools-uikit/secondary-button';
23
23
  | Props | Type | Required | Values | Default | Description |
24
24
  | ------------------ | --------------------- | :------: | --------------------------- | ----------- | ------------------------------------------------------------------------------------------------------------------------------------------------ |
25
25
  | `label` | `string` | ✅ | - | - | Should describe what the button does, for accessibility purposes (screen-reader users) |
26
- | `iconLeft` | `node` | | - | - | The left icon displayed within the button |
26
+ | `iconLeft` | `node` | - | - | - | The left icon displayed within the button |
27
+ | `iconRight` | `node` | - | - | - | The right icon displayed within the button |
27
28
  | `isToggleButton` | `bool` | ✅ | - | `false` | 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 |
28
29
  | `isToggled` | `bool` | - | - | - | Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is false |
29
30
  | `theme` | `string` | - | `default`, `info` | `default` | The component may have a theme only if `isToggleButton` is true. 
This property has been **deprecated** in favor of `tone`. |
@@ -88,6 +88,7 @@ const getToneStyles = (tone, isDisabled, isActive) => {
88
88
 
89
89
  function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
90
90
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context2 = ownKeys(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(t))).call(_context3, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
91
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
91
92
  /**
92
93
  * Mapping of legacy sizes to new sizes.
93
94
  */
@@ -97,14 +98,14 @@ const sizeMapping = {
97
98
  big: '20'
98
99
  };
99
100
  // Gets the color which the icon sho√uld have based on context of button's state/cursor behavior
100
- const getIconColor = props => {
101
+ const getIconColor = (props, icon) => {
101
102
  const isActive = props.isToggleButton && props.isToggled;
102
103
  // if button has a theme, icon should be the same color as the theme on active state
103
104
  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting
104
105
  // if button is disabled, icon should be grey
105
106
  if (props.isDisabled) return 'neutral60';
106
107
  // if button is not disabled nor has a theme, return icon's default color
107
- return props.iconLeft?.props.color;
108
+ return icon?.props.color;
108
109
  };
109
110
  const defaultProps = {
110
111
  type: 'button',
@@ -113,6 +114,27 @@ const defaultProps = {
113
114
  size: '20',
114
115
  isToggleButton: false
115
116
  };
117
+ var _ref = process.env.NODE_ENV === "production" ? {
118
+ name: "1wnowod",
119
+ styles: "display:flex;align-items:center;justify-content:center"
120
+ } : {
121
+ name: "17kup4k-PositionedIcon",
122
+ styles: "display:flex;align-items:center;justify-content:center;label:PositionedIcon;",
123
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAuJc","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 defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\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  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.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={props.size}\n            color={getIconColor(props, props.iconLeft)}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={props.size}\n            color={getIconColor(props, props.iconRight)}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */",
124
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
125
+ };
126
+ const PositionedIcon = _ref2 => {
127
+ let size = _ref2.size,
128
+ icon = _ref2.icon,
129
+ color = _ref2.color;
130
+ return jsxRuntime.jsx("span", {
131
+ css: _ref,
132
+ children: /*#__PURE__*/react$1.cloneElement(icon, {
133
+ color,
134
+ size: size === 'big' || size === '20' ? '40' : '20'
135
+ })
136
+ });
137
+ };
116
138
  const SecondaryButton = props => {
117
139
  var _context;
118
140
  const isActive = Boolean(props.isToggleButton && props.isToggled);
@@ -124,7 +146,7 @@ const SecondaryButton = props => {
124
146
  } : {});
125
147
  process.env.NODE_ENV !== "production" ? utils.warning(!(props.theme !== 'default' && !props.isToggleButton), `Invalid prop \`theme\` supplied to \`SecondaryButton\`. Only toggle buttons may have a theme.`) : void 0;
126
148
  utils.useWarning(!Boolean(_indexOfInstanceProperty__default["default"](_context = _Object$keys__default["default"](sizeMapping)).call(_context, props.size) > -1), `SecondaryButton '${props.size}' value for 'size' property has been deprecated in favor of '${sizeMapping[props.size]}' Please update that value when using this component`);
127
- 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":"AAmKO","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   * 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' | 'iconLeft'\n  > & {\n    isActive?: boolean;\n  }\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 props.iconLeft?.props.color;\n};\n\nconst defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>(\n  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"xs\">\n        {Boolean(props.iconLeft) && (\n          <span\n            css={css`\n              margin: 0 ${designTokens.spacing10} 0 0;\n              display: flex;\n              align-items: center;\n              justify-content: center;\n            `}\n          >\n            {props.iconLeft &&\n              cloneElement(props.iconLeft, {\n                color: getIconColor(props),\n                size: props.size === 'big' || props.size === '20' ? '40' : '20',\n              })}\n          </span>\n        )}\n        <span>{props.label}</span>\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\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":"AAyKO","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   * 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' | 'iconLeft'\n  > & {\n    isActive?: boolean;\n  }\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 props.iconLeft?.props.color;\n};\n\nconst defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>(\n  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"xs\">\n        {Boolean(props.iconLeft) && (\n          <span\n            css={css`\n              margin: 0 ${designTokens.spacing10} 0 0;\n              display: flex;\n              align-items: center;\n              justify-content: center;\n            `}\n          >\n            {props.iconLeft &&\n              cloneElement(props.iconLeft, {\n                color: getIconColor(props),\n                size: props.size === 'big' || props.size === '20' ? '40' : '20',\n              })}\n          </span>\n        )}\n        <span>{props.label}</span>\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(props.theme), getStateStyles(props.isDisabled, isActive, props.tone), getSizeStyles(props.size), getToneStyles(props.tone, props.isDisabled, isActive)];
149
+ 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 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 defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\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  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.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={props.size}\n            color={getIconColor(props, props.iconLeft)}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={props.size}\n            color={getIconColor(props, props.iconRight)}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\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 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 defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\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  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.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={props.size}\n            color={getIconColor(props, props.iconLeft)}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={props.size}\n            color={getIconColor(props, props.iconRight)}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(props.theme), getStateStyles(props.isDisabled, isActive, props.tone), getSizeStyles(props.size), getToneStyles(props.tone, props.isDisabled, isActive)];
128
150
  return jsxRuntime.jsx(AccessibleButton__default["default"], {
129
151
  as: shouldUseLinkTag ? reactRouterDom.Link : props.as,
130
152
  type: props.type,
@@ -137,15 +159,17 @@ const SecondaryButton = props => {
137
159
  css: containerStyles,
138
160
  children: jsxRuntime.jsxs(Inline__default["default"], {
139
161
  alignItems: "center",
140
- scale: "xs",
141
- children: [Boolean(props.iconLeft) && jsxRuntime.jsx("span", {
142
- css: /*#__PURE__*/react.css("margin:0 ", designSystem.designTokens.spacing10, " 0 0;display:flex;align-items:center;justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:SecondaryButton;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAwMoB","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   * 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' | 'iconLeft'\n  > & {\n    isActive?: boolean;\n  }\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 props.iconLeft?.props.color;\n};\n\nconst defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>(\n  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"xs\">\n        {Boolean(props.iconLeft) && (\n          <span\n            css={css`\n              margin: 0 ${designTokens.spacing10} 0 0;\n              display: flex;\n              align-items: center;\n              justify-content: center;\n            `}\n          >\n            {props.iconLeft &&\n              cloneElement(props.iconLeft, {\n                color: getIconColor(props),\n                size: props.size === 'big' || props.size === '20' ? '40' : '20',\n              })}\n          </span>\n        )}\n        <span>{props.label}</span>\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */"),
143
- children: props.iconLeft && /*#__PURE__*/react$1.cloneElement(props.iconLeft, {
144
- color: getIconColor(props),
145
- size: props.size === 'big' || props.size === '20' ? '40' : '20'
146
- })
162
+ scale: "s",
163
+ children: [props.iconLeft && jsxRuntime.jsx(PositionedIcon, {
164
+ icon: props.iconLeft,
165
+ size: props.size,
166
+ color: getIconColor(props, props.iconLeft)
147
167
  }), jsxRuntime.jsx("span", {
148
168
  children: props.label
169
+ }), props.iconRight && jsxRuntime.jsx(PositionedIcon, {
170
+ icon: props.iconRight,
171
+ size: props.size,
172
+ color: getIconColor(props, props.iconRight)
149
173
  })]
150
174
  })
151
175
  });
@@ -155,6 +179,7 @@ SecondaryButton.propTypes = process.env.NODE_ENV !== "production" ? {
155
179
  type: _pt__default["default"].oneOf(['button', 'reset', 'submit']),
156
180
  label: _pt__default["default"].string.isRequired,
157
181
  iconLeft: _pt__default["default"].element,
182
+ iconRight: _pt__default["default"].element,
158
183
  isToggleButton: _pt__default["default"].bool,
159
184
  isToggled: _pt__default["default"].bool,
160
185
  isDisabled: _pt__default["default"].bool,
@@ -168,7 +193,7 @@ SecondaryButton.defaultProps = defaultProps;
168
193
  var SecondaryButton$1 = SecondaryButton;
169
194
 
170
195
  // NOTE: This string will be replaced on build time with the package version.
171
- var version = "19.12.1";
196
+ var version = "19.14.0";
172
197
 
173
198
  exports["default"] = SecondaryButton$1;
174
199
  exports.version = version;
@@ -95,14 +95,14 @@ const sizeMapping = {
95
95
  big: '20'
96
96
  };
97
97
  // Gets the color which the icon sho√uld have based on context of button's state/cursor behavior
98
- const getIconColor = props => {
98
+ const getIconColor = (props, icon) => {
99
99
  const isActive = props.isToggleButton && props.isToggled;
100
100
  // if button has a theme, icon should be the same color as the theme on active state
101
101
  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting
102
102
  // if button is disabled, icon should be grey
103
103
  if (props.isDisabled) return 'neutral60';
104
104
  // if button is not disabled nor has a theme, return icon's default color
105
- return props.iconLeft?.props.color;
105
+ return icon?.props.color;
106
106
  };
107
107
  const defaultProps = {
108
108
  type: 'button',
@@ -111,6 +111,22 @@ const defaultProps = {
111
111
  size: '20',
112
112
  isToggleButton: false
113
113
  };
114
+ var _ref = {
115
+ name: "1wnowod",
116
+ styles: "display:flex;align-items:center;justify-content:center"
117
+ } ;
118
+ const PositionedIcon = _ref2 => {
119
+ let size = _ref2.size,
120
+ icon = _ref2.icon,
121
+ color = _ref2.color;
122
+ return jsxRuntime.jsx("span", {
123
+ css: _ref,
124
+ children: /*#__PURE__*/react$1.cloneElement(icon, {
125
+ color,
126
+ size: size === 'big' || size === '20' ? '40' : '20'
127
+ })
128
+ });
129
+ };
114
130
  const SecondaryButton = props => {
115
131
  var _context;
116
132
  const isActive = Boolean(props.isToggleButton && props.isToggled);
@@ -134,15 +150,17 @@ const SecondaryButton = props => {
134
150
  css: containerStyles,
135
151
  children: jsxRuntime.jsxs(Inline__default["default"], {
136
152
  alignItems: "center",
137
- scale: "xs",
138
- children: [Boolean(props.iconLeft) && jsxRuntime.jsx("span", {
139
- css: /*#__PURE__*/react.css("margin:0 ", designSystem.designTokens.spacing10, " 0 0;display:flex;align-items:center;justify-content:center;" + ("" ), "" ),
140
- children: props.iconLeft && /*#__PURE__*/react$1.cloneElement(props.iconLeft, {
141
- color: getIconColor(props),
142
- size: props.size === 'big' || props.size === '20' ? '40' : '20'
143
- })
153
+ scale: "s",
154
+ children: [props.iconLeft && jsxRuntime.jsx(PositionedIcon, {
155
+ icon: props.iconLeft,
156
+ size: props.size,
157
+ color: getIconColor(props, props.iconLeft)
144
158
  }), jsxRuntime.jsx("span", {
145
159
  children: props.label
160
+ }), props.iconRight && jsxRuntime.jsx(PositionedIcon, {
161
+ icon: props.iconRight,
162
+ size: props.size,
163
+ color: getIconColor(props, props.iconRight)
146
164
  })]
147
165
  })
148
166
  });
@@ -153,7 +171,7 @@ SecondaryButton.defaultProps = defaultProps;
153
171
  var SecondaryButton$1 = SecondaryButton;
154
172
 
155
173
  // NOTE: This string will be replaced on build time with the package version.
156
- var version = "19.12.1";
174
+ var version = "19.14.0";
157
175
 
158
176
  exports["default"] = SecondaryButton$1;
159
177
  exports.version = version;
@@ -69,6 +69,7 @@ const getToneStyles = (tone, isDisabled, isActive) => {
69
69
 
70
70
  function ownKeys(e, r) { var t = _Object$keys(e); if (_Object$getOwnPropertySymbols) { var o = _Object$getOwnPropertySymbols(e); r && (o = _filterInstanceProperty(o).call(o, function (r) { return _Object$getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
71
71
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context2, _context3; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty(_context2 = ownKeys(Object(t), !0)).call(_context2, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(e, _Object$getOwnPropertyDescriptors(t)) : _forEachInstanceProperty(_context3 = ownKeys(Object(t))).call(_context3, function (r) { _Object$defineProperty(e, r, _Object$getOwnPropertyDescriptor(t, r)); }); } return e; }
72
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
72
73
  /**
73
74
  * Mapping of legacy sizes to new sizes.
74
75
  */
@@ -78,14 +79,14 @@ const sizeMapping = {
78
79
  big: '20'
79
80
  };
80
81
  // Gets the color which the icon sho√uld have based on context of button's state/cursor behavior
81
- const getIconColor = props => {
82
+ const getIconColor = (props, icon) => {
82
83
  const isActive = props.isToggleButton && props.isToggled;
83
84
  // if button has a theme, icon should be the same color as the theme on active state
84
85
  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting
85
86
  // if button is disabled, icon should be grey
86
87
  if (props.isDisabled) return 'neutral60';
87
88
  // if button is not disabled nor has a theme, return icon's default color
88
- return props.iconLeft?.props.color;
89
+ return icon?.props.color;
89
90
  };
90
91
  const defaultProps = {
91
92
  type: 'button',
@@ -94,6 +95,27 @@ const defaultProps = {
94
95
  size: '20',
95
96
  isToggleButton: false
96
97
  };
98
+ var _ref = process.env.NODE_ENV === "production" ? {
99
+ name: "1wnowod",
100
+ styles: "display:flex;align-items:center;justify-content:center"
101
+ } : {
102
+ name: "17kup4k-PositionedIcon",
103
+ styles: "display:flex;align-items:center;justify-content:center;label:PositionedIcon;",
104
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAuJc","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 defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\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  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.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={props.size}\n            color={getIconColor(props, props.iconLeft)}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={props.size}\n            color={getIconColor(props, props.iconRight)}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */",
105
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
106
+ };
107
+ const PositionedIcon = _ref2 => {
108
+ let size = _ref2.size,
109
+ icon = _ref2.icon,
110
+ color = _ref2.color;
111
+ return jsx("span", {
112
+ css: _ref,
113
+ children: /*#__PURE__*/cloneElement(icon, {
114
+ color,
115
+ size: size === 'big' || size === '20' ? '40' : '20'
116
+ })
117
+ });
118
+ };
97
119
  const SecondaryButton = props => {
98
120
  var _context;
99
121
  const isActive = Boolean(props.isToggleButton && props.isToggled);
@@ -105,7 +127,7 @@ const SecondaryButton = props => {
105
127
  } : {});
106
128
  process.env.NODE_ENV !== "production" ? warning(!(props.theme !== 'default' && !props.isToggleButton), `Invalid prop \`theme\` supplied to \`SecondaryButton\`. Only toggle buttons may have a theme.`) : void 0;
107
129
  useWarning(!Boolean(_indexOfInstanceProperty(_context = _Object$keys(sizeMapping)).call(_context, props.size) > -1), `SecondaryButton '${props.size}' value for 'size' property has been deprecated in favor of '${sizeMapping[props.size]}' Please update that value when using this component`);
108
- 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":"AAmKO","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   * 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' | 'iconLeft'\n  > & {\n    isActive?: boolean;\n  }\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 props.iconLeft?.props.color;\n};\n\nconst defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>(\n  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"xs\">\n        {Boolean(props.iconLeft) && (\n          <span\n            css={css`\n              margin: 0 ${designTokens.spacing10} 0 0;\n              display: flex;\n              align-items: center;\n              justify-content: center;\n            `}\n          >\n            {props.iconLeft &&\n              cloneElement(props.iconLeft, {\n                color: getIconColor(props),\n                size: props.size === 'big' || props.size === '20' ? '40' : '20',\n              })}\n          </span>\n        )}\n        <span>{props.label}</span>\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\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":"AAyKO","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   * 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' | 'iconLeft'\n  > & {\n    isActive?: boolean;\n  }\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 props.iconLeft?.props.color;\n};\n\nconst defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>(\n  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"xs\">\n        {Boolean(props.iconLeft) && (\n          <span\n            css={css`\n              margin: 0 ${designTokens.spacing10} 0 0;\n              display: flex;\n              align-items: center;\n              justify-content: center;\n            `}\n          >\n            {props.iconLeft &&\n              cloneElement(props.iconLeft, {\n                color: getIconColor(props),\n                size: props.size === 'big' || props.size === '20' ? '40' : '20',\n              })}\n          </span>\n        )}\n        <span>{props.label}</span>\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(props.theme), getStateStyles(props.isDisabled, isActive, props.tone), getSizeStyles(props.size), getToneStyles(props.tone, props.isDisabled, isActive)];
130
+ 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 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 defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\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  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.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={props.size}\n            color={getIconColor(props, props.iconLeft)}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={props.size}\n            color={getIconColor(props, props.iconRight)}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\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 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 defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\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  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.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={props.size}\n            color={getIconColor(props, props.iconLeft)}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={props.size}\n            color={getIconColor(props, props.iconRight)}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(props.theme), getStateStyles(props.isDisabled, isActive, props.tone), getSizeStyles(props.size), getToneStyles(props.tone, props.isDisabled, isActive)];
109
131
  return jsx(AccessibleButton, {
110
132
  as: shouldUseLinkTag ? Link : props.as,
111
133
  type: props.type,
@@ -118,15 +140,17 @@ const SecondaryButton = props => {
118
140
  css: containerStyles,
119
141
  children: jsxs(Inline, {
120
142
  alignItems: "center",
121
- scale: "xs",
122
- children: [Boolean(props.iconLeft) && jsx("span", {
123
- css: /*#__PURE__*/css("margin:0 ", designTokens.spacing10, " 0 0;display:flex;align-items:center;justify-content:center;" + (process.env.NODE_ENV === "production" ? "" : ";label:SecondaryButton;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAwMoB","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   * 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' | 'iconLeft'\n  > & {\n    isActive?: boolean;\n  }\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 props.iconLeft?.props.color;\n};\n\nconst defaultProps: Pick<\n  TSecondaryButtonProps,\n  'type' | 'theme' | 'size' | 'isToggleButton' | 'tone'\n> = {\n  type: 'button',\n  theme: 'default',\n  tone: 'secondary',\n  size: '20',\n  isToggleButton: false,\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>(\n  props: TSecondaryButtonProps<TStringOrComponent>\n) => {\n  const isActive = Boolean(props.isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes(props),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(props.theme !== 'default' && !props.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(props.size) > -1),\n    `SecondaryButton '${\n      props.size\n    }' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[props.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(props.theme),\n    getStateStyles(props.isDisabled, isActive, props.tone),\n    getSizeStyles(props.size),\n    getToneStyles(props.tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={props.type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={props.isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"xs\">\n        {Boolean(props.iconLeft) && (\n          <span\n            css={css`\n              margin: 0 ${designTokens.spacing10} 0 0;\n              display: flex;\n              align-items: center;\n              justify-content: center;\n            `}\n          >\n            {props.iconLeft &&\n              cloneElement(props.iconLeft, {\n                color: getIconColor(props),\n                size: props.size === 'big' || props.size === '20' ? '40' : '20',\n              })}\n          </span>\n        )}\n        <span>{props.label}</span>\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\nSecondaryButton.defaultProps = defaultProps;\n\nexport default SecondaryButton;\n"]} */"),
124
- children: props.iconLeft && /*#__PURE__*/cloneElement(props.iconLeft, {
125
- color: getIconColor(props),
126
- size: props.size === 'big' || props.size === '20' ? '40' : '20'
127
- })
143
+ scale: "s",
144
+ children: [props.iconLeft && jsx(PositionedIcon, {
145
+ icon: props.iconLeft,
146
+ size: props.size,
147
+ color: getIconColor(props, props.iconLeft)
128
148
  }), jsx("span", {
129
149
  children: props.label
150
+ }), props.iconRight && jsx(PositionedIcon, {
151
+ icon: props.iconRight,
152
+ size: props.size,
153
+ color: getIconColor(props, props.iconRight)
130
154
  })]
131
155
  })
132
156
  });
@@ -136,6 +160,7 @@ SecondaryButton.propTypes = process.env.NODE_ENV !== "production" ? {
136
160
  type: _pt.oneOf(['button', 'reset', 'submit']),
137
161
  label: _pt.string.isRequired,
138
162
  iconLeft: _pt.element,
163
+ iconRight: _pt.element,
139
164
  isToggleButton: _pt.bool,
140
165
  isToggled: _pt.bool,
141
166
  isDisabled: _pt.bool,
@@ -149,6 +174,6 @@ SecondaryButton.defaultProps = defaultProps;
149
174
  var SecondaryButton$1 = SecondaryButton;
150
175
 
151
176
  // NOTE: This string will be replaced on build time with the package version.
152
- var version = "19.12.1";
177
+ var version = "19.14.0";
153
178
 
154
179
  export { SecondaryButton$1 as default, version };
@@ -27,6 +27,10 @@ export type TSecondaryButtonProps<TStringOrComponent extends ElementType = 'butt
27
27
  * The left icon displayed within the button.
28
28
  */
29
29
  iconLeft?: ReactElement;
30
+ /**
31
+ * The righr icon displayed within the button.
32
+ */
33
+ iconRight?: ReactElement;
30
34
  /**
31
35
  * 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
32
36
  */
@@ -63,12 +67,12 @@ export type TSecondaryButtonProps<TStringOrComponent extends ElementType = 'butt
63
67
  * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be
64
68
  * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to="/foo" label="Foo" />.
65
69
  */ ComponentPropsWithRef<TStringOrComponent>;
66
- export declare const getIconColor: (props: Pick<TSecondaryButtonProps, "isToggleButton" | "isToggled" | "theme" | "isDisabled" | "iconLeft"> & {
70
+ export declare const getIconColor: (props: Pick<TSecondaryButtonProps, "isToggleButton" | "isToggled" | "theme" | "isDisabled"> & {
67
71
  isActive?: boolean;
68
- }) => any;
72
+ }, icon: TSecondaryButtonProps["iconLeft"] | TSecondaryButtonProps["iconRight"]) => any;
69
73
  export declare const SecondaryButton: {
70
74
  <TStringOrComponent extends ElementType = "button">(props: TSecondaryButtonProps<TStringOrComponent>): import("@emotion/react/jsx-runtime").JSX.Element;
71
75
  displayName: string;
72
- defaultProps: Pick<TSecondaryButtonProps<"button">, "type" | "theme" | "size" | "tone" | "isToggleButton">;
76
+ defaultProps: Pick<TSecondaryButtonProps<"button">, "size" | "type" | "theme" | "tone" | "isToggleButton">;
73
77
  };
74
78
  export default SecondaryButton;
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": "19.12.1",
4
+ "version": "19.14.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,11 +21,11 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
- "@commercetools-uikit/accessible-button": "19.12.1",
25
- "@commercetools-uikit/design-system": "19.12.1",
26
- "@commercetools-uikit/spacings-inline": "19.12.1",
27
- "@commercetools-uikit/text": "19.12.1",
28
- "@commercetools-uikit/utils": "19.12.1",
24
+ "@commercetools-uikit/accessible-button": "19.14.0",
25
+ "@commercetools-uikit/design-system": "19.14.0",
26
+ "@commercetools-uikit/spacings-inline": "19.14.0",
27
+ "@commercetools-uikit/text": "19.14.0",
28
+ "@commercetools-uikit/utils": "19.14.0",
29
29
  "@emotion/react": "^11.10.5",
30
30
  "@emotion/styled": "^11.10.5",
31
31
  "lodash": "4.17.21",