@commercetools-uikit/secondary-button 19.20.0 → 19.21.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.
|
@@ -10,6 +10,7 @@ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-
|
|
|
10
10
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
11
11
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
12
12
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
13
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
13
14
|
var _pt = require('prop-types');
|
|
14
15
|
var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
|
|
15
16
|
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
@@ -86,6 +87,7 @@ const getToneStyles = (tone, isDisabled, isActive) => {
|
|
|
86
87
|
}
|
|
87
88
|
};
|
|
88
89
|
|
|
90
|
+
const _excluded = ["type", "theme", "tone", "size", "isToggleButton"];
|
|
89
91
|
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
92
|
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
93
|
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)."; }
|
|
@@ -107,20 +109,13 @@ const getIconColor = (props, icon) => {
|
|
|
107
109
|
// if button is not disabled nor has a theme, return icon's default color
|
|
108
110
|
return icon?.props.color;
|
|
109
111
|
};
|
|
110
|
-
const defaultProps = {
|
|
111
|
-
type: 'button',
|
|
112
|
-
theme: 'default',
|
|
113
|
-
tone: 'secondary',
|
|
114
|
-
size: '20',
|
|
115
|
-
isToggleButton: false
|
|
116
|
-
};
|
|
117
112
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
118
113
|
name: "1wnowod",
|
|
119
114
|
styles: "display:flex;align-items:center;justify-content:center"
|
|
120
115
|
} : {
|
|
121
116
|
name: "17kup4k-PositionedIcon",
|
|
122
117
|
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"]} */",
|
|
118
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AA4Ic","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */",
|
|
124
119
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
125
120
|
};
|
|
126
121
|
const PositionedIcon = _ref2 => {
|
|
@@ -135,25 +130,42 @@ const PositionedIcon = _ref2 => {
|
|
|
135
130
|
})
|
|
136
131
|
});
|
|
137
132
|
};
|
|
138
|
-
const SecondaryButton =
|
|
133
|
+
const SecondaryButton = _ref3 => {
|
|
139
134
|
var _context;
|
|
140
|
-
|
|
135
|
+
let _ref3$type = _ref3.type,
|
|
136
|
+
type = _ref3$type === void 0 ? 'button' : _ref3$type,
|
|
137
|
+
_ref3$theme = _ref3.theme,
|
|
138
|
+
theme = _ref3$theme === void 0 ? 'default' : _ref3$theme,
|
|
139
|
+
_ref3$tone = _ref3.tone,
|
|
140
|
+
tone = _ref3$tone === void 0 ? 'secondary' : _ref3$tone,
|
|
141
|
+
_ref3$size = _ref3.size,
|
|
142
|
+
size = _ref3$size === void 0 ? '20' : _ref3$size,
|
|
143
|
+
_ref3$isToggleButton = _ref3.isToggleButton,
|
|
144
|
+
isToggleButton = _ref3$isToggleButton === void 0 ? false : _ref3$isToggleButton,
|
|
145
|
+
props = _objectWithoutProperties(_ref3, _excluded);
|
|
146
|
+
const isActive = Boolean(isToggleButton && props.isToggled);
|
|
141
147
|
const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);
|
|
142
148
|
const buttonAttributes = _objectSpread(_objectSpread({
|
|
143
149
|
'data-track-component': 'SecondaryButton'
|
|
144
|
-
}, utils.filterInvalidAttributes(
|
|
150
|
+
}, utils.filterInvalidAttributes(_objectSpread({
|
|
151
|
+
type,
|
|
152
|
+
theme,
|
|
153
|
+
tone,
|
|
154
|
+
size,
|
|
155
|
+
isToggleButton
|
|
156
|
+
}, props))), shouldUseLinkTag ? {
|
|
145
157
|
to: props.to
|
|
146
158
|
} : {});
|
|
147
|
-
process.env.NODE_ENV !== "production" ? utils.warning(!(
|
|
148
|
-
utils.useWarning(!Boolean(_indexOfInstanceProperty__default["default"](_context = _Object$keys__default["default"](sizeMapping)).call(_context,
|
|
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)];
|
|
159
|
+
process.env.NODE_ENV !== "production" ? utils.warning(!(theme !== 'default' && !isToggleButton), `Invalid prop \`theme\` supplied to \`SecondaryButton\`. Only toggle buttons may have a theme.`) : void 0;
|
|
160
|
+
utils.useWarning(!Boolean(_indexOfInstanceProperty__default["default"](_context = _Object$keys__default["default"](sizeMapping)).call(_context, size) > -1), `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${sizeMapping[size]}' Please update that value when using this component`);
|
|
161
|
+
const containerStyles = [/*#__PURE__*/react.css("display:flex;align-items:center;padding:0 ", designSystem.designTokens.spacing30, ";height:", designSystem.designTokens.heightForButtonAs40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAgMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), /*#__PURE__*/react.css("display:inline-flex;background-color:", designSystem.designTokens.colorSurface, ";border:1px solid ", designSystem.designTokens.colorNeutral, ";border-radius:", designSystem.designTokens.borderRadius4, ";box-shadow:", designSystem.designTokens.shadow0, ";color:", designSystem.designTokens.colorSolid, ";transition:background-color ", designSystem.designTokens.transitionLinear80Ms, ",box-shadow ", designSystem.designTokens.transitionEaseinout150Ms, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAsMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(theme), getStateStyles(props.isDisabled, isActive, tone), getSizeStyles(size), getToneStyles(tone, props.isDisabled, isActive)];
|
|
150
162
|
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
151
163
|
as: shouldUseLinkTag ? reactRouterDom.Link : props.as,
|
|
152
|
-
type:
|
|
164
|
+
type: type,
|
|
153
165
|
buttonAttributes: buttonAttributes,
|
|
154
166
|
label: props.label,
|
|
155
167
|
onClick: props.onClick,
|
|
156
|
-
isToggleButton:
|
|
168
|
+
isToggleButton: isToggleButton,
|
|
157
169
|
isToggled: props.isToggled,
|
|
158
170
|
isDisabled: props.isDisabled,
|
|
159
171
|
css: containerStyles,
|
|
@@ -162,14 +174,26 @@ const SecondaryButton = props => {
|
|
|
162
174
|
scale: "s",
|
|
163
175
|
children: [props.iconLeft && jsxRuntime.jsx(PositionedIcon, {
|
|
164
176
|
icon: props.iconLeft,
|
|
165
|
-
size:
|
|
166
|
-
color: getIconColor(
|
|
177
|
+
size: size,
|
|
178
|
+
color: getIconColor(_objectSpread({
|
|
179
|
+
type,
|
|
180
|
+
theme,
|
|
181
|
+
tone,
|
|
182
|
+
size,
|
|
183
|
+
isToggleButton
|
|
184
|
+
}, props), props.iconLeft)
|
|
167
185
|
}), jsxRuntime.jsx("span", {
|
|
168
186
|
children: props.label
|
|
169
187
|
}), props.iconRight && jsxRuntime.jsx(PositionedIcon, {
|
|
170
188
|
icon: props.iconRight,
|
|
171
|
-
size:
|
|
172
|
-
color: getIconColor(
|
|
189
|
+
size: size,
|
|
190
|
+
color: getIconColor(_objectSpread({
|
|
191
|
+
type,
|
|
192
|
+
theme,
|
|
193
|
+
tone,
|
|
194
|
+
size,
|
|
195
|
+
isToggleButton
|
|
196
|
+
}, props), props.iconRight)
|
|
173
197
|
})]
|
|
174
198
|
})
|
|
175
199
|
});
|
|
@@ -189,11 +213,10 @@ SecondaryButton.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
189
213
|
tone: _pt__default["default"].oneOf(['secondary', 'info'])
|
|
190
214
|
} : {};
|
|
191
215
|
SecondaryButton.displayName = 'SecondaryButton';
|
|
192
|
-
SecondaryButton.defaultProps = defaultProps;
|
|
193
216
|
var SecondaryButton$1 = SecondaryButton;
|
|
194
217
|
|
|
195
218
|
// NOTE: This string will be replaced on build time with the package version.
|
|
196
|
-
var version = "19.
|
|
219
|
+
var version = "19.21.0";
|
|
197
220
|
|
|
198
221
|
exports["default"] = SecondaryButton$1;
|
|
199
222
|
exports.version = version;
|
|
@@ -10,6 +10,7 @@ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-
|
|
|
10
10
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
11
11
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
12
12
|
var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
|
|
13
|
+
var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
|
|
13
14
|
require('prop-types');
|
|
14
15
|
var _indexOfInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/index-of');
|
|
15
16
|
var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
|
|
@@ -84,6 +85,7 @@ const getToneStyles = (tone, isDisabled, isActive) => {
|
|
|
84
85
|
}
|
|
85
86
|
};
|
|
86
87
|
|
|
88
|
+
const _excluded = ["type", "theme", "tone", "size", "isToggleButton"];
|
|
87
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; }
|
|
88
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; }
|
|
89
91
|
/**
|
|
@@ -104,13 +106,6 @@ const getIconColor = (props, icon) => {
|
|
|
104
106
|
// if button is not disabled nor has a theme, return icon's default color
|
|
105
107
|
return icon?.props.color;
|
|
106
108
|
};
|
|
107
|
-
const defaultProps = {
|
|
108
|
-
type: 'button',
|
|
109
|
-
theme: 'default',
|
|
110
|
-
tone: 'secondary',
|
|
111
|
-
size: '20',
|
|
112
|
-
isToggleButton: false
|
|
113
|
-
};
|
|
114
109
|
var _ref = {
|
|
115
110
|
name: "1wnowod",
|
|
116
111
|
styles: "display:flex;align-items:center;justify-content:center"
|
|
@@ -127,24 +122,41 @@ const PositionedIcon = _ref2 => {
|
|
|
127
122
|
})
|
|
128
123
|
});
|
|
129
124
|
};
|
|
130
|
-
const SecondaryButton =
|
|
125
|
+
const SecondaryButton = _ref3 => {
|
|
131
126
|
var _context;
|
|
132
|
-
|
|
127
|
+
let _ref3$type = _ref3.type,
|
|
128
|
+
type = _ref3$type === void 0 ? 'button' : _ref3$type,
|
|
129
|
+
_ref3$theme = _ref3.theme,
|
|
130
|
+
theme = _ref3$theme === void 0 ? 'default' : _ref3$theme,
|
|
131
|
+
_ref3$tone = _ref3.tone,
|
|
132
|
+
tone = _ref3$tone === void 0 ? 'secondary' : _ref3$tone,
|
|
133
|
+
_ref3$size = _ref3.size,
|
|
134
|
+
size = _ref3$size === void 0 ? '20' : _ref3$size,
|
|
135
|
+
_ref3$isToggleButton = _ref3.isToggleButton,
|
|
136
|
+
isToggleButton = _ref3$isToggleButton === void 0 ? false : _ref3$isToggleButton,
|
|
137
|
+
props = _objectWithoutProperties(_ref3, _excluded);
|
|
138
|
+
const isActive = Boolean(isToggleButton && props.isToggled);
|
|
133
139
|
const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);
|
|
134
140
|
const buttonAttributes = _objectSpread(_objectSpread({
|
|
135
141
|
'data-track-component': 'SecondaryButton'
|
|
136
|
-
}, utils.filterInvalidAttributes(
|
|
142
|
+
}, utils.filterInvalidAttributes(_objectSpread({
|
|
143
|
+
type,
|
|
144
|
+
theme,
|
|
145
|
+
tone,
|
|
146
|
+
size,
|
|
147
|
+
isToggleButton
|
|
148
|
+
}, props))), shouldUseLinkTag ? {
|
|
137
149
|
to: props.to
|
|
138
150
|
} : {});
|
|
139
|
-
utils.useWarning(!Boolean(_indexOfInstanceProperty__default["default"](_context = _Object$keys__default["default"](sizeMapping)).call(_context,
|
|
140
|
-
const containerStyles = [/*#__PURE__*/react.css("display:flex;align-items:center;padding:0 ", designSystem.designTokens.spacing30, ";height:", designSystem.designTokens.heightForButtonAs40, ";" + ("" ), "" ), /*#__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, ";" + ("" ), "" ), getThemeStyles(
|
|
151
|
+
utils.useWarning(!Boolean(_indexOfInstanceProperty__default["default"](_context = _Object$keys__default["default"](sizeMapping)).call(_context, size) > -1), `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${sizeMapping[size]}' Please update that value when using this component`);
|
|
152
|
+
const containerStyles = [/*#__PURE__*/react.css("display:flex;align-items:center;padding:0 ", designSystem.designTokens.spacing30, ";height:", designSystem.designTokens.heightForButtonAs40, ";" + ("" ), "" ), /*#__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, ";" + ("" ), "" ), getThemeStyles(theme), getStateStyles(props.isDisabled, isActive, tone), getSizeStyles(size), getToneStyles(tone, props.isDisabled, isActive)];
|
|
141
153
|
return jsxRuntime.jsx(AccessibleButton__default["default"], {
|
|
142
154
|
as: shouldUseLinkTag ? reactRouterDom.Link : props.as,
|
|
143
|
-
type:
|
|
155
|
+
type: type,
|
|
144
156
|
buttonAttributes: buttonAttributes,
|
|
145
157
|
label: props.label,
|
|
146
158
|
onClick: props.onClick,
|
|
147
|
-
isToggleButton:
|
|
159
|
+
isToggleButton: isToggleButton,
|
|
148
160
|
isToggled: props.isToggled,
|
|
149
161
|
isDisabled: props.isDisabled,
|
|
150
162
|
css: containerStyles,
|
|
@@ -153,25 +165,36 @@ const SecondaryButton = props => {
|
|
|
153
165
|
scale: "s",
|
|
154
166
|
children: [props.iconLeft && jsxRuntime.jsx(PositionedIcon, {
|
|
155
167
|
icon: props.iconLeft,
|
|
156
|
-
size:
|
|
157
|
-
color: getIconColor(
|
|
168
|
+
size: size,
|
|
169
|
+
color: getIconColor(_objectSpread({
|
|
170
|
+
type,
|
|
171
|
+
theme,
|
|
172
|
+
tone,
|
|
173
|
+
size,
|
|
174
|
+
isToggleButton
|
|
175
|
+
}, props), props.iconLeft)
|
|
158
176
|
}), jsxRuntime.jsx("span", {
|
|
159
177
|
children: props.label
|
|
160
178
|
}), props.iconRight && jsxRuntime.jsx(PositionedIcon, {
|
|
161
179
|
icon: props.iconRight,
|
|
162
|
-
size:
|
|
163
|
-
color: getIconColor(
|
|
180
|
+
size: size,
|
|
181
|
+
color: getIconColor(_objectSpread({
|
|
182
|
+
type,
|
|
183
|
+
theme,
|
|
184
|
+
tone,
|
|
185
|
+
size,
|
|
186
|
+
isToggleButton
|
|
187
|
+
}, props), props.iconRight)
|
|
164
188
|
})]
|
|
165
189
|
})
|
|
166
190
|
});
|
|
167
191
|
};
|
|
168
192
|
SecondaryButton.propTypes = {};
|
|
169
193
|
SecondaryButton.displayName = 'SecondaryButton';
|
|
170
|
-
SecondaryButton.defaultProps = defaultProps;
|
|
171
194
|
var SecondaryButton$1 = SecondaryButton;
|
|
172
195
|
|
|
173
196
|
// NOTE: This string will be replaced on build time with the package version.
|
|
174
|
-
var version = "19.
|
|
197
|
+
var version = "19.21.0";
|
|
175
198
|
|
|
176
199
|
exports["default"] = SecondaryButton$1;
|
|
177
200
|
exports.version = version;
|
|
@@ -6,6 +6,7 @@ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-st
|
|
|
6
6
|
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
7
7
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
8
8
|
import _defineProperty from '@babel/runtime-corejs3/helpers/esm/defineProperty';
|
|
9
|
+
import _objectWithoutProperties from '@babel/runtime-corejs3/helpers/esm/objectWithoutProperties';
|
|
9
10
|
import _pt from 'prop-types';
|
|
10
11
|
import _indexOfInstanceProperty from '@babel/runtime-corejs3/core-js-stable/instance/index-of';
|
|
11
12
|
import _Object$keys from '@babel/runtime-corejs3/core-js-stable/object/keys';
|
|
@@ -67,6 +68,7 @@ const getToneStyles = (tone, isDisabled, isActive) => {
|
|
|
67
68
|
}
|
|
68
69
|
};
|
|
69
70
|
|
|
71
|
+
const _excluded = ["type", "theme", "tone", "size", "isToggleButton"];
|
|
70
72
|
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
73
|
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
74
|
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)."; }
|
|
@@ -88,20 +90,13 @@ const getIconColor = (props, icon) => {
|
|
|
88
90
|
// if button is not disabled nor has a theme, return icon's default color
|
|
89
91
|
return icon?.props.color;
|
|
90
92
|
};
|
|
91
|
-
const defaultProps = {
|
|
92
|
-
type: 'button',
|
|
93
|
-
theme: 'default',
|
|
94
|
-
tone: 'secondary',
|
|
95
|
-
size: '20',
|
|
96
|
-
isToggleButton: false
|
|
97
|
-
};
|
|
98
93
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
99
94
|
name: "1wnowod",
|
|
100
95
|
styles: "display:flex;align-items:center;justify-content:center"
|
|
101
96
|
} : {
|
|
102
97
|
name: "17kup4k-PositionedIcon",
|
|
103
98
|
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"]} */",
|
|
99
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AA4Ic","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */",
|
|
105
100
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
106
101
|
};
|
|
107
102
|
const PositionedIcon = _ref2 => {
|
|
@@ -116,25 +111,42 @@ const PositionedIcon = _ref2 => {
|
|
|
116
111
|
})
|
|
117
112
|
});
|
|
118
113
|
};
|
|
119
|
-
const SecondaryButton =
|
|
114
|
+
const SecondaryButton = _ref3 => {
|
|
120
115
|
var _context;
|
|
121
|
-
|
|
116
|
+
let _ref3$type = _ref3.type,
|
|
117
|
+
type = _ref3$type === void 0 ? 'button' : _ref3$type,
|
|
118
|
+
_ref3$theme = _ref3.theme,
|
|
119
|
+
theme = _ref3$theme === void 0 ? 'default' : _ref3$theme,
|
|
120
|
+
_ref3$tone = _ref3.tone,
|
|
121
|
+
tone = _ref3$tone === void 0 ? 'secondary' : _ref3$tone,
|
|
122
|
+
_ref3$size = _ref3.size,
|
|
123
|
+
size = _ref3$size === void 0 ? '20' : _ref3$size,
|
|
124
|
+
_ref3$isToggleButton = _ref3.isToggleButton,
|
|
125
|
+
isToggleButton = _ref3$isToggleButton === void 0 ? false : _ref3$isToggleButton,
|
|
126
|
+
props = _objectWithoutProperties(_ref3, _excluded);
|
|
127
|
+
const isActive = Boolean(isToggleButton && props.isToggled);
|
|
122
128
|
const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);
|
|
123
129
|
const buttonAttributes = _objectSpread(_objectSpread({
|
|
124
130
|
'data-track-component': 'SecondaryButton'
|
|
125
|
-
}, filterInvalidAttributes(
|
|
131
|
+
}, filterInvalidAttributes(_objectSpread({
|
|
132
|
+
type,
|
|
133
|
+
theme,
|
|
134
|
+
tone,
|
|
135
|
+
size,
|
|
136
|
+
isToggleButton
|
|
137
|
+
}, props))), shouldUseLinkTag ? {
|
|
126
138
|
to: props.to
|
|
127
139
|
} : {});
|
|
128
|
-
process.env.NODE_ENV !== "production" ? warning(!(
|
|
129
|
-
useWarning(!Boolean(_indexOfInstanceProperty(_context = _Object$keys(sizeMapping)).call(_context,
|
|
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)];
|
|
140
|
+
process.env.NODE_ENV !== "production" ? warning(!(theme !== 'default' && !isToggleButton), `Invalid prop \`theme\` supplied to \`SecondaryButton\`. Only toggle buttons may have a theme.`) : void 0;
|
|
141
|
+
useWarning(!Boolean(_indexOfInstanceProperty(_context = _Object$keys(sizeMapping)).call(_context, size) > -1), `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${sizeMapping[size]}' Please update that value when using this component`);
|
|
142
|
+
const containerStyles = [/*#__PURE__*/css("display:flex;align-items:center;padding:0 ", designTokens.spacing30, ";height:", designTokens.heightForButtonAs40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAgMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), /*#__PURE__*/css("display:inline-flex;background-color:", designTokens.colorSurface, ";border:1px solid ", designTokens.colorNeutral, ";border-radius:", designTokens.borderRadius4, ";box-shadow:", designTokens.shadow0, ";color:", designTokens.colorSolid, ";transition:background-color ", designTokens.transitionLinear80Ms, ",box-shadow ", designTokens.transitionEaseinout150Ms, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:containerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["secondary-button.tsx"],"names":[],"mappings":"AAsMO","file":"secondary-button.tsx","sourcesContent":["import {\n  ReactElement,\n  KeyboardEvent,\n  MouseEvent,\n  ComponentType,\n  ElementType,\n  ComponentPropsWithRef,\n  cloneElement,\n} from 'react';\nimport { Link } from 'react-router-dom';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport Inline from '@commercetools-uikit/spacings-inline';\nimport {\n  filterInvalidAttributes,\n  useWarning,\n  warning,\n} from '@commercetools-uikit/utils';\nimport AccessibleButton from '@commercetools-uikit/accessible-button';\nimport {\n  getStateStyles,\n  getThemeStyles,\n  getSizeStyles,\n  getToneStyles,\n} from './secondary-button.styles';\n\n/**\n * @deprecated Use sizes from `TSizes` instead.\n */\ntype TLegacySizes = 'small' | 'medium' | 'big';\n\n/**\n * Available sizes for the SecondaryButton.\n */\ntype TSizes = '10' | '20';\n\n/**\n * Mapping of legacy sizes to new sizes.\n */\nconst sizeMapping: Record<TLegacySizes, TSizes> = {\n  small: '10',\n  medium: '10',\n  big: '20',\n};\n\nexport type TSecondaryButtonProps<\n  TStringOrComponent extends ElementType = 'button'\n> = {\n  /**\n   * You may pass in a string like \"a\" to have the button element render an anchor tag, or\n   * you could pass in a React Component, like a `Link`.\n   * <br />\n   * The `<SecondaryButton>` additionally accepts any props or attributes specific to the given element or component.\n   */\n  as?: TStringOrComponent;\n  /**\n   * Used as the HTML type attribute.\n   */\n  type?: 'button' | 'reset' | 'submit';\n  /**\n   * Should describe what the button does, for accessibility purposes (screen-reader users)\n   */\n  label: string;\n  /**\n   * The left icon displayed within the button.\n   */\n  iconLeft?: ReactElement;\n  /**\n   * The righr icon displayed within the button.\n   */\n  iconRight?: ReactElement;\n  /**\n   * If this is active, it means the button will persist in an \"active\" state when toggled (see `isToggled`), and back to normal state when untoggled\n   */\n  isToggleButton?: boolean;\n  /**\n   * Tells when the button should present a toggled state. It does not have any effect when `isToggleButton` is `false`.\n   */\n  isToggled?: boolean;\n  /**\n   * Tells when the button should present a disabled state.\n   */\n  isDisabled?: boolean;\n  /**\n   * Handler when the button is clicked.\n   */\n  onClick?: (\n    event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * Sets the size of the button.\n   * <br />\n   * `small`, `medium`, and `big` are deprecated. Use `10` or `20`, instead.\n   */\n  size?: TLegacySizes | TSizes;\n  /**\n   * Indicates the color scheme of the button.\n   * @deprecated Use `tone` instead.\n   */\n  theme?: 'default' | 'info';\n  /**\n   * Indicates the tone of the button.\n   */\n  tone?: 'secondary' | 'info';\n} & /**\n * Include any props derived from the React component passed to the `as` prop.\n * For example, given `as={Link}`, all props of the `<Link>` component are allowed to be\n * passed to `<SecondaryButton>`: <SecondaryButton as={Link} to=\"/foo\" label=\"Foo\" />.\n */ ComponentPropsWithRef<TStringOrComponent>;\n\n// Gets the color which the icon sho√uld have based on context of button's state/cursor behavior\nexport const getIconColor = (\n  props: Pick<\n    TSecondaryButtonProps,\n    'isToggleButton' | 'isToggled' | 'theme' | 'isDisabled'\n  > & {\n    isActive?: boolean;\n  },\n  icon: TSecondaryButtonProps['iconLeft'] | TSecondaryButtonProps['iconRight']\n) => {\n  const isActive = props.isToggleButton && props.isToggled;\n  // if button has a theme, icon should be the same color as the theme on active state\n  if (props.theme !== 'default' && isActive && !props.isDisabled) return 'info'; // returns the passed in theme without overwriting\n  // if button is disabled, icon should be grey\n  if (props.isDisabled) return 'neutral60';\n  // if button is not disabled nor has a theme, return icon's default color\n  return icon?.props.color;\n};\n\nconst PositionedIcon = ({\n  size,\n  icon,\n  color,\n}: {\n  size: string;\n  icon: ReactElement;\n  color: string;\n}) => {\n  return (\n    <span\n      css={css`\n        display: flex;\n        align-items: center;\n        justify-content: center;\n      `}\n    >\n      {cloneElement(icon, {\n        color,\n        size: size === 'big' || size === '20' ? '40' : '20',\n      })}\n    </span>\n  );\n};\n\nexport const SecondaryButton = <\n  TStringOrComponent extends ElementType = 'button'\n>({\n  type = 'button',\n  theme = 'default',\n  tone = 'secondary',\n  size = '20',\n  isToggleButton = false,\n  ...props\n}: TSecondaryButtonProps<TStringOrComponent>) => {\n  const isActive = Boolean(isToggleButton && props.isToggled);\n  const shouldUseLinkTag = !props.isDisabled && Boolean(props.to);\n  const buttonAttributes = {\n    'data-track-component': 'SecondaryButton',\n    ...filterInvalidAttributes({\n      type,\n      theme,\n      tone,\n      size,\n      isToggleButton,\n      ...props,\n    }),\n    ...(shouldUseLinkTag ? { to: props.to } : {}),\n  };\n\n  warning(\n    !(theme !== 'default' && !isToggleButton),\n    `Invalid prop \\`theme\\` supplied to \\`SecondaryButton\\`. Only toggle buttons may have a theme.`\n  );\n\n  useWarning(\n    !Boolean(Object.keys(sizeMapping).indexOf(size) > -1),\n    `SecondaryButton '${size}' value for 'size' property has been deprecated in favor of '${\n      sizeMapping[size as TLegacySizes]\n    }' Please update that value when using this component`\n  );\n\n  const containerStyles = [\n    css`\n      display: flex;\n      align-items: center;\n      padding: 0 ${designTokens.spacing30};\n      height: ${designTokens.heightForButtonAs40};\n    `,\n    css`\n      display: inline-flex;\n      background-color: ${designTokens.colorSurface};\n      border: 1px solid ${designTokens.colorNeutral};\n      border-radius: ${designTokens.borderRadius4};\n      box-shadow: ${designTokens.shadow0};\n      color: ${designTokens.colorSolid};\n      transition: background-color ${designTokens.transitionLinear80Ms},\n        box-shadow ${designTokens.transitionEaseinout150Ms};\n    `,\n    getThemeStyles(theme),\n    getStateStyles(props.isDisabled, isActive, tone),\n    getSizeStyles(size),\n    getToneStyles(tone, props.isDisabled, isActive),\n  ];\n\n  return (\n    <AccessibleButton\n      as={(shouldUseLinkTag ? Link : props.as) as ComponentType}\n      type={type}\n      buttonAttributes={buttonAttributes}\n      label={props.label}\n      onClick={props.onClick}\n      isToggleButton={isToggleButton}\n      isToggled={props.isToggled}\n      isDisabled={props.isDisabled}\n      css={containerStyles}\n    >\n      <Inline alignItems=\"center\" scale=\"s\">\n        {props.iconLeft && (\n          <PositionedIcon\n            icon={props.iconLeft}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconLeft\n            )}\n          />\n        )}\n        <span>{props.label}</span>\n        {props.iconRight && (\n          <PositionedIcon\n            icon={props.iconRight}\n            size={size}\n            color={getIconColor(\n              {\n                type,\n                theme,\n                tone,\n                size,\n                isToggleButton,\n                ...props,\n              },\n              props.iconRight\n            )}\n          />\n        )}\n      </Inline>\n    </AccessibleButton>\n  );\n};\n\nSecondaryButton.displayName = 'SecondaryButton';\n\nexport default SecondaryButton;\n"]} */"), getThemeStyles(theme), getStateStyles(props.isDisabled, isActive, tone), getSizeStyles(size), getToneStyles(tone, props.isDisabled, isActive)];
|
|
131
143
|
return jsx(AccessibleButton, {
|
|
132
144
|
as: shouldUseLinkTag ? Link : props.as,
|
|
133
|
-
type:
|
|
145
|
+
type: type,
|
|
134
146
|
buttonAttributes: buttonAttributes,
|
|
135
147
|
label: props.label,
|
|
136
148
|
onClick: props.onClick,
|
|
137
|
-
isToggleButton:
|
|
149
|
+
isToggleButton: isToggleButton,
|
|
138
150
|
isToggled: props.isToggled,
|
|
139
151
|
isDisabled: props.isDisabled,
|
|
140
152
|
css: containerStyles,
|
|
@@ -143,14 +155,26 @@ const SecondaryButton = props => {
|
|
|
143
155
|
scale: "s",
|
|
144
156
|
children: [props.iconLeft && jsx(PositionedIcon, {
|
|
145
157
|
icon: props.iconLeft,
|
|
146
|
-
size:
|
|
147
|
-
color: getIconColor(
|
|
158
|
+
size: size,
|
|
159
|
+
color: getIconColor(_objectSpread({
|
|
160
|
+
type,
|
|
161
|
+
theme,
|
|
162
|
+
tone,
|
|
163
|
+
size,
|
|
164
|
+
isToggleButton
|
|
165
|
+
}, props), props.iconLeft)
|
|
148
166
|
}), jsx("span", {
|
|
149
167
|
children: props.label
|
|
150
168
|
}), props.iconRight && jsx(PositionedIcon, {
|
|
151
169
|
icon: props.iconRight,
|
|
152
|
-
size:
|
|
153
|
-
color: getIconColor(
|
|
170
|
+
size: size,
|
|
171
|
+
color: getIconColor(_objectSpread({
|
|
172
|
+
type,
|
|
173
|
+
theme,
|
|
174
|
+
tone,
|
|
175
|
+
size,
|
|
176
|
+
isToggleButton
|
|
177
|
+
}, props), props.iconRight)
|
|
154
178
|
})]
|
|
155
179
|
})
|
|
156
180
|
});
|
|
@@ -170,10 +194,9 @@ SecondaryButton.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
170
194
|
tone: _pt.oneOf(['secondary', 'info'])
|
|
171
195
|
} : {};
|
|
172
196
|
SecondaryButton.displayName = 'SecondaryButton';
|
|
173
|
-
SecondaryButton.defaultProps = defaultProps;
|
|
174
197
|
var SecondaryButton$1 = SecondaryButton;
|
|
175
198
|
|
|
176
199
|
// NOTE: This string will be replaced on build time with the package version.
|
|
177
|
-
var version = "19.
|
|
200
|
+
var version = "19.21.0";
|
|
178
201
|
|
|
179
202
|
export { SecondaryButton$1 as default, version };
|
|
@@ -71,8 +71,7 @@ export declare const getIconColor: (props: Pick<TSecondaryButtonProps, "isToggle
|
|
|
71
71
|
isActive?: boolean;
|
|
72
72
|
}, icon: TSecondaryButtonProps["iconLeft"] | TSecondaryButtonProps["iconRight"]) => any;
|
|
73
73
|
export declare const SecondaryButton: {
|
|
74
|
-
<TStringOrComponent extends ElementType = "button">(props: TSecondaryButtonProps<TStringOrComponent>): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
74
|
+
<TStringOrComponent extends ElementType = "button">({ type, theme, tone, size, isToggleButton, ...props }: TSecondaryButtonProps<TStringOrComponent>): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
75
75
|
displayName: string;
|
|
76
|
-
defaultProps: Pick<TSecondaryButtonProps<"button">, "size" | "type" | "theme" | "tone" | "isToggleButton">;
|
|
77
76
|
};
|
|
78
77
|
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.21.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.21.0",
|
|
25
|
+
"@commercetools-uikit/design-system": "19.21.0",
|
|
26
|
+
"@commercetools-uikit/spacings-inline": "19.21.0",
|
|
27
|
+
"@commercetools-uikit/text": "19.21.0",
|
|
28
|
+
"@commercetools-uikit/utils": "19.21.0",
|
|
29
29
|
"@emotion/react": "^11.10.5",
|
|
30
30
|
"@emotion/styled": "^11.10.5",
|
|
31
31
|
"lodash": "4.17.21",
|