@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 +2 -1
- package/dist/commercetools-uikit-secondary-button.cjs.dev.js +36 -11
- package/dist/commercetools-uikit-secondary-button.cjs.prod.js +28 -10
- package/dist/commercetools-uikit-secondary-button.esm.js +36 -11
- package/dist/declarations/src/secondary-button.d.ts +7 -3
- package/package.json +6 -6
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` |
|
|
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
|
|
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: "
|
|
141
|
-
children: [
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
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.
|
|
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
|
|
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: "
|
|
138
|
-
children: [
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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.
|
|
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
|
|
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: "
|
|
122
|
-
children: [
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
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.
|
|
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"
|
|
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">, "
|
|
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.
|
|
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.
|
|
25
|
-
"@commercetools-uikit/design-system": "19.
|
|
26
|
-
"@commercetools-uikit/spacings-inline": "19.
|
|
27
|
-
"@commercetools-uikit/text": "19.
|
|
28
|
-
"@commercetools-uikit/utils": "19.
|
|
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",
|