@commercetools-uikit/checkbox-input 18.4.0 → 19.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -289,7 +289,7 @@ const defaultProps = {
289
289
  isDisabled: false,
290
290
  hasError: false
291
291
  };
292
- const getBorderColor = props => {
292
+ const getBorderColor = (props, isRecolouringTheme) => {
293
293
  if (props.hasError) {
294
294
  return designSystem.designTokens.colorError;
295
295
  }
@@ -299,7 +299,10 @@ const getBorderColor = props => {
299
299
  if (props.isReadOnly) {
300
300
  return designSystem.designTokens.colorNeutral60;
301
301
  }
302
- return designSystem.designTokens.colorPrimary;
302
+ if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {
303
+ return designSystem.designTokens.borderColorForCheckboxInputWhenActive;
304
+ }
305
+ return designSystem.designTokens.borderColorForCheckboxInput;
303
306
  };
304
307
  const getBackgroundColor = props => {
305
308
  if (props.isChecked || props.isIndeterminate) {
@@ -333,15 +336,17 @@ const LabelTextWrapper = /*#__PURE__*/_styled__default["default"]("div", process
333
336
  } : {
334
337
  target: "e6nn4mw2",
335
338
  label: "LabelTextWrapper"
336
- })("margin-left:calc(", designSystem.designTokens.spacing20, " - ", designSystem.designTokens.borderWidth2, ");outline:none;border-radius:", designSystem.designTokens.borderRadius2, ";font-size:", designSystem.designTokens.fontSize30, ";line-height:", designSystem.designTokens.lineHeight40, ";font-weight:", designSystem.designTokens.fontWeight400, ";color:", props => getTextColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA0HgD","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
339
+ })("margin-left:calc(", designSystem.designTokens.spacing20, " - ", designSystem.designTokens.borderWidth2, ");outline:none;border-radius:", designSystem.designTokens.borderRadius2, ";font-size:", designSystem.designTokens.fontSize30, ";line-height:", designSystem.designTokens.lineHeight40, ";font-weight:", designSystem.designTokens.fontWeight400, ";color:", props => getTextColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA6HgD","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
337
340
  const CheckboxIconWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
338
341
  target: "e6nn4mw1"
339
342
  } : {
340
343
  target: "e6nn4mw1",
341
344
  label: "CheckboxIconWrapper"
342
- })("width:", props => props.width, ";height:", props => props.height, ";display:flex;flex-shrink:0;align-items:center;justify-content:center;border-radius:", designSystem.designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/react.css("background-color:", designSystem.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIconWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAqJW","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */") : '', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA0IiE","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
345
+ })("width:", props => props.width, ";height:", props => props.height, ";display:flex;flex-shrink:0;align-items:center;justify-content:center;border-radius:", designSystem.designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/react.css("background-color:", designSystem.designTokens.backgroundColorForCheckboxInputWhenHovered, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIconWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAwJW","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */") : '', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA6IiE","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
343
346
  const CheckboxIcon = props => {
344
347
  var _context;
348
+ const _useTheme = designSystem.useTheme(),
349
+ isRecolouringTheme = _useTheme.isRecolouringTheme;
345
350
  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;
346
351
  const canForcedHoverEffect = Boolean(props.isHovered && !isDisabledOrReadOnlyState);
347
352
  return jsxRuntime.jsx(CheckboxIconWrapper, {
@@ -349,7 +354,7 @@ const CheckboxIcon = props => {
349
354
  height: "26px",
350
355
  isHovered: canForcedHoverEffect,
351
356
  children: jsxRuntime.jsx("div", {
352
- css: _filterInstanceProperty__default["default"](_context = [/*#__PURE__*/react.css("border-width:", designSystem.designTokens.borderWidth2, ";border-radius:", designSystem.designTokens.borderRadius2, ";border-color:", getBorderColor(props), ";border-style:solid;background-color:", getBackgroundColor(props), ";padding:1px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;svg>path[stroke]{stroke:", designSystem.designTokens.colorSurface, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAwKa","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */")]).call(_context, Boolean),
357
+ css: _filterInstanceProperty__default["default"](_context = [/*#__PURE__*/react.css("border-width:", designSystem.designTokens.borderWidth2, ";border-radius:", designSystem.designTokens.borderRadius2, ";border-color:", getBorderColor(props, isRecolouringTheme), ";border-style:solid;background-color:", getBackgroundColor(props), ";padding:1px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;svg>path[stroke]{stroke:", designSystem.designTokens.colorSurface, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA4Ka","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */")]).call(_context, Boolean),
353
358
  children: (() => {
354
359
  if (props.isIndeterminate) return jsxRuntime.jsx(IndeterminateIcon$1, {
355
360
  color: "surface",
@@ -373,7 +378,7 @@ const Label = /*#__PURE__*/_styled__default["default"]("label", process.env.NODE
373
378
  if (props.isDisabled) return 'not-allowed';
374
379
  if (props.isReadOnly) return 'default';
375
380
  return 'pointer';
376
- }, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designSystem.designTokens.colorNeutral90, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAuMuC","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
381
+ }, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designSystem.designTokens.backgroundColorForCheckboxInputWhenHovered, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA2MuC","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
377
382
  const CheckboxInput = props => {
378
383
  // We generate an id in case no id is provided by the parent to attach the
379
384
  // label to the input component.
@@ -427,7 +432,7 @@ CheckboxInput.defaultProps = defaultProps;
427
432
  var CheckboxInput$1 = CheckboxInput;
428
433
 
429
434
  // NOTE: This string will be replaced on build time with the package version.
430
- var version = "18.4.0";
435
+ var version = "19.0.0";
431
436
 
432
437
  exports["default"] = CheckboxInput$1;
433
438
  exports.version = version;
@@ -286,7 +286,7 @@ const defaultProps = {
286
286
  isDisabled: false,
287
287
  hasError: false
288
288
  };
289
- const getBorderColor = props => {
289
+ const getBorderColor = (props, isRecolouringTheme) => {
290
290
  if (props.hasError) {
291
291
  return designSystem.designTokens.colorError;
292
292
  }
@@ -296,7 +296,10 @@ const getBorderColor = props => {
296
296
  if (props.isReadOnly) {
297
297
  return designSystem.designTokens.colorNeutral60;
298
298
  }
299
- return designSystem.designTokens.colorPrimary;
299
+ if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {
300
+ return designSystem.designTokens.borderColorForCheckboxInputWhenActive;
301
+ }
302
+ return designSystem.designTokens.borderColorForCheckboxInput;
300
303
  };
301
304
  const getBackgroundColor = props => {
302
305
  if (props.isChecked || props.isIndeterminate) {
@@ -330,9 +333,11 @@ const LabelTextWrapper = /*#__PURE__*/_styled__default["default"]("div", {
330
333
  } )("margin-left:calc(", designSystem.designTokens.spacing20, " - ", designSystem.designTokens.borderWidth2, ");outline:none;border-radius:", designSystem.designTokens.borderRadius2, ";font-size:", designSystem.designTokens.fontSize30, ";line-height:", designSystem.designTokens.lineHeight40, ";font-weight:", designSystem.designTokens.fontWeight400, ";color:", props => getTextColor(props), ";" + ("" ));
331
334
  const CheckboxIconWrapper = /*#__PURE__*/_styled__default["default"]("div", {
332
335
  target: "e6nn4mw1"
333
- } )("width:", props => props.width, ";height:", props => props.height, ";display:flex;flex-shrink:0;align-items:center;justify-content:center;border-radius:", designSystem.designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/react.css("background-color:", designSystem.designTokens.colorNeutral90, ";" + ("" ), "" ) : '', ";" + ("" ));
336
+ } )("width:", props => props.width, ";height:", props => props.height, ";display:flex;flex-shrink:0;align-items:center;justify-content:center;border-radius:", designSystem.designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/react.css("background-color:", designSystem.designTokens.backgroundColorForCheckboxInputWhenHovered, ";" + ("" ), "" ) : '', ";" + ("" ));
334
337
  const CheckboxIcon = props => {
335
338
  var _context;
339
+ const _useTheme = designSystem.useTheme(),
340
+ isRecolouringTheme = _useTheme.isRecolouringTheme;
336
341
  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;
337
342
  const canForcedHoverEffect = Boolean(props.isHovered && !isDisabledOrReadOnlyState);
338
343
  return jsxRuntime.jsx(CheckboxIconWrapper, {
@@ -340,7 +345,7 @@ const CheckboxIcon = props => {
340
345
  height: "26px",
341
346
  isHovered: canForcedHoverEffect,
342
347
  children: jsxRuntime.jsx("div", {
343
- css: _filterInstanceProperty__default["default"](_context = [/*#__PURE__*/react.css("border-width:", designSystem.designTokens.borderWidth2, ";border-radius:", designSystem.designTokens.borderRadius2, ";border-color:", getBorderColor(props), ";border-style:solid;background-color:", getBackgroundColor(props), ";padding:1px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;svg>path[stroke]{stroke:", designSystem.designTokens.colorSurface, ";}" + ("" ), "" )]).call(_context, Boolean),
348
+ css: _filterInstanceProperty__default["default"](_context = [/*#__PURE__*/react.css("border-width:", designSystem.designTokens.borderWidth2, ";border-radius:", designSystem.designTokens.borderRadius2, ";border-color:", getBorderColor(props, isRecolouringTheme), ";border-style:solid;background-color:", getBackgroundColor(props), ";padding:1px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;svg>path[stroke]{stroke:", designSystem.designTokens.colorSurface, ";}" + ("" ), "" )]).call(_context, Boolean),
344
349
  children: (() => {
345
350
  if (props.isIndeterminate) return jsxRuntime.jsx(IndeterminateIcon$1, {
346
351
  color: "surface",
@@ -361,7 +366,7 @@ const Label = /*#__PURE__*/_styled__default["default"]("label", {
361
366
  if (props.isDisabled) return 'not-allowed';
362
367
  if (props.isReadOnly) return 'default';
363
368
  return 'pointer';
364
- }, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designSystem.designTokens.colorNeutral90, ";}" + ("" ));
369
+ }, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designSystem.designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designSystem.designTokens.backgroundColorForCheckboxInputWhenHovered, ";}" + ("" ));
365
370
  const CheckboxInput = props => {
366
371
  // We generate an id in case no id is provided by the parent to attach the
367
372
  // label to the input component.
@@ -403,7 +408,7 @@ CheckboxInput.defaultProps = defaultProps;
403
408
  var CheckboxInput$1 = CheckboxInput;
404
409
 
405
410
  // NOTE: This string will be replaced on build time with the package version.
406
- var version = "18.4.0";
411
+ var version = "19.0.0";
407
412
 
408
413
  exports["default"] = CheckboxInput$1;
409
414
  exports.version = version;
@@ -10,7 +10,7 @@ import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-st
10
10
  import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
11
11
  import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
12
12
  import { ClassNames, css } from '@emotion/react';
13
- import { designTokens } from '@commercetools-uikit/design-system';
13
+ import { designTokens, useTheme } from '@commercetools-uikit/design-system';
14
14
  import { warning, filterDataAttributes, filterAriaAttributes, createSequentialId } from '@commercetools-uikit/utils';
15
15
  import { useRef, useEffect } from 'react';
16
16
  import { accessibleHiddenInputStyles } from '@commercetools-uikit/input-utils';
@@ -271,7 +271,7 @@ const defaultProps = {
271
271
  isDisabled: false,
272
272
  hasError: false
273
273
  };
274
- const getBorderColor = props => {
274
+ const getBorderColor = (props, isRecolouringTheme) => {
275
275
  if (props.hasError) {
276
276
  return designTokens.colorError;
277
277
  }
@@ -281,7 +281,10 @@ const getBorderColor = props => {
281
281
  if (props.isReadOnly) {
282
282
  return designTokens.colorNeutral60;
283
283
  }
284
- return designTokens.colorPrimary;
284
+ if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {
285
+ return designTokens.borderColorForCheckboxInputWhenActive;
286
+ }
287
+ return designTokens.borderColorForCheckboxInput;
285
288
  };
286
289
  const getBackgroundColor = props => {
287
290
  if (props.isChecked || props.isIndeterminate) {
@@ -315,15 +318,17 @@ const LabelTextWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "p
315
318
  } : {
316
319
  target: "e6nn4mw2",
317
320
  label: "LabelTextWrapper"
318
- })("margin-left:calc(", designTokens.spacing20, " - ", designTokens.borderWidth2, ");outline:none;border-radius:", designTokens.borderRadius2, ";font-size:", designTokens.fontSize30, ";line-height:", designTokens.lineHeight40, ";font-weight:", designTokens.fontWeight400, ";color:", props => getTextColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA0HgD","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
321
+ })("margin-left:calc(", designTokens.spacing20, " - ", designTokens.borderWidth2, ");outline:none;border-radius:", designTokens.borderRadius2, ";font-size:", designTokens.fontSize30, ";line-height:", designTokens.lineHeight40, ";font-weight:", designTokens.fontWeight400, ";color:", props => getTextColor(props), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA6HgD","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
319
322
  const CheckboxIconWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
320
323
  target: "e6nn4mw1"
321
324
  } : {
322
325
  target: "e6nn4mw1",
323
326
  label: "CheckboxIconWrapper"
324
- })("width:", props => props.width, ";height:", props => props.height, ";display:flex;flex-shrink:0;align-items:center;justify-content:center;border-radius:", designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/css("background-color:", designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIconWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAqJW","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */") : '', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA0IiE","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
327
+ })("width:", props => props.width, ";height:", props => props.height, ";display:flex;flex-shrink:0;align-items:center;justify-content:center;border-radius:", designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/css("background-color:", designTokens.backgroundColorForCheckboxInputWhenHovered, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIconWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAwJW","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */") : '', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA6IiE","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
325
328
  const CheckboxIcon = props => {
326
329
  var _context;
330
+ const _useTheme = useTheme(),
331
+ isRecolouringTheme = _useTheme.isRecolouringTheme;
327
332
  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;
328
333
  const canForcedHoverEffect = Boolean(props.isHovered && !isDisabledOrReadOnlyState);
329
334
  return jsx(CheckboxIconWrapper, {
@@ -331,7 +336,7 @@ const CheckboxIcon = props => {
331
336
  height: "26px",
332
337
  isHovered: canForcedHoverEffect,
333
338
  children: jsx("div", {
334
- css: _filterInstanceProperty(_context = [/*#__PURE__*/css("border-width:", designTokens.borderWidth2, ";border-radius:", designTokens.borderRadius2, ";border-color:", getBorderColor(props), ";border-style:solid;background-color:", getBackgroundColor(props), ";padding:1px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;svg>path[stroke]{stroke:", designTokens.colorSurface, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAwKa","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */")]).call(_context, Boolean),
339
+ css: _filterInstanceProperty(_context = [/*#__PURE__*/css("border-width:", designTokens.borderWidth2, ";border-radius:", designTokens.borderRadius2, ";border-color:", getBorderColor(props, isRecolouringTheme), ";border-style:solid;background-color:", getBackgroundColor(props), ";padding:1px;width:18px;height:18px;display:flex;align-items:center;justify-content:center;svg>path[stroke]{stroke:", designTokens.colorSurface, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:CheckboxIcon;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA4Ka","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */")]).call(_context, Boolean),
335
340
  children: (() => {
336
341
  if (props.isIndeterminate) return jsx(IndeterminateIcon$1, {
337
342
  color: "surface",
@@ -355,7 +360,7 @@ const Label = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "production
355
360
  if (props.isDisabled) return 'not-allowed';
356
361
  if (props.isReadOnly) return 'default';
357
362
  return 'pointer';
358
- }, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designTokens.colorNeutral90, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAuMuC","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  return designTokens.colorPrimary;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.colorNeutral90};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.colorNeutral90};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
363
+ }, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designTokens.backgroundColorForCheckboxInputWhenHovered, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AA2MuC","file":"checkbox-input.tsx","sourcesContent":["import type { ChangeEventHandler, ReactNode } from 'react';\nimport styled from '@emotion/styled';\nimport { css } from '@emotion/react';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { createSequentialId } from '@commercetools-uikit/utils';\nimport { IndeterminateIcon, CheckedIcon } from './icons';\nimport Checkbox from './checkbox';\n\nconst sequentialId = createSequentialId('checkbox-input-');\n\nexport type TCheckboxProps = {\n  /**\n   * Used as HTML id attribute. An id is auto-generated when it is not specified.\n   */\n  id?: string;\n  /**\n   * Used as HTML name attribute of the input component\n   */\n  name?: string;\n  /**\n   * Value of the input component.\n   */\n  value?: string;\n  /**\n   * The checked property sets the checked state of the checkbox.\n   */\n  isChecked?: boolean;\n  /**\n   * If `true`, this state is shown as a dash in the checkbox, and indicates that its state is neither checked nor unchecked.\n   * This is most often used when the checkbox is tied to a collection of items in mixed states (E.g nested checkboxes).\n   * This takes precedence visually in case `isChecked` is marked as `true`\n   */\n  isIndeterminate?: boolean;\n  /**\n   *  Will be triggered whenever an `CheckboxInput` is clicked. Called with `event`\n   */\n  onChange: ChangeEventHandler<HTMLInputElement>;\n  /**\n   * Forces CheckboxInput to be rendered in a hovered state.\n   * Needed for cases when hovered appearance should be triggered by the parent component and not the CheckboxInput itself.\n   * CheckboxInput is capable of handling it's own hovering without the need to pass this prop.\n   */\n  isHovered?: boolean;\n  /**\n   * Disables the CheckboxInput\n   */\n  isDisabled?: boolean;\n  /**\n   * Makes the CheckboxInput readonly\n   */\n  isReadOnly?: boolean;\n  /**\n   * Indicates that the checkbox has an error\n   */\n  hasError?: boolean;\n  /**\n   * The descriptive text of the CheckboxInput, used as its label.\n   */\n  children?: ReactNode;\n};\n\ntype TLabelProps = Pick<\n  TCheckboxProps,\n  | 'hasError'\n  | 'isDisabled'\n  | 'isReadOnly'\n  | 'isChecked'\n  | 'isIndeterminate'\n  | 'isHovered'\n>;\n\nconst defaultProps: Pick<\n  TCheckboxProps,\n  'isChecked' | 'isDisabled' | 'hasError'\n> = {\n  isChecked: false,\n  isDisabled: false,\n  hasError: false,\n};\n\nconst getBorderColor = (props: TLabelProps, isRecolouringTheme: boolean) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral60;\n  }\n  if ((props.isChecked || props.isIndeterminate) && isRecolouringTheme) {\n    return designTokens.borderColorForCheckboxInputWhenActive;\n  }\n  return designTokens.borderColorForCheckboxInput;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.colorError;\n    }\n    if (props.isDisabled) {\n      return designTokens.colorNeutral;\n    }\n    if (props.isReadOnly) {\n      return designTokens.colorNeutral60;\n    }\n    return designTokens.colorPrimary;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.colorError;\n  }\n  if (props.isDisabled) {\n    return designTokens.colorNeutral60;\n  }\n  if (props.isReadOnly) {\n    return designTokens.colorNeutral40;\n  }\n  return designTokens.colorSolid;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(${designTokens.spacing20} - ${designTokens.borderWidth2});\n  outline: none;\n  border-radius: ${designTokens.borderRadius2};\n\n  font-size: ${designTokens.fontSize30};\n  line-height: ${designTokens.lineHeight40};\n  font-weight: ${designTokens.fontWeight400};\n  color: ${(props) => getTextColor(props)};\n`;\n\ntype TCheckboxIconWrapperProps = {\n  width: string;\n  height: string;\n  isHovered: boolean;\n};\nconst CheckboxIconWrapper = styled.div<TCheckboxIconWrapperProps>`\n  width: ${(props) => props.width};\n  height: ${(props) => props.height};\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputWhenHovered};\n        `\n      : ''}\n`;\n\nconst CheckboxIcon = (props: TLabelProps) => {\n  const { isRecolouringTheme } = useTheme();\n  const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;\n  const canForcedHoverEffect = Boolean(\n    props.isHovered && !isDisabledOrReadOnlyState\n  );\n  return (\n    <CheckboxIconWrapper\n      width=\"26px\"\n      height=\"26px\"\n      isHovered={canForcedHoverEffect}\n    >\n      <div\n        css={[\n          css`\n            border-width: ${designTokens.borderWidth2};\n            border-radius: ${designTokens.borderRadius2};\n            border-color: ${getBorderColor(props, isRecolouringTheme)};\n            border-style: solid;\n            background-color: ${getBackgroundColor(props)};\n            padding: 1px;\n            width: 18px;\n            height: 18px;\n            display: flex;\n            align-items: center;\n            justify-content: center;\n\n            svg > path[stroke] {\n              stroke: ${designTokens.colorSurface};\n            }\n          `,\n        ].filter(Boolean)}\n      >\n        {(() => {\n          if (props.isIndeterminate)\n            return <IndeterminateIcon color=\"surface\" size=\"scale\" />;\n          if (props.isChecked)\n            return <CheckedIcon color=\"surface\" size=\"scale\" />;\n          return null;\n        })()}\n      </div>\n    </CheckboxIconWrapper>\n  );\n};\n\nconst Label = styled.label<TLabelProps>`\n  display: flex;\n  align-items: center;\n  cursor: ${(props) => {\n    if (props.isDisabled) return 'not-allowed';\n    if (props.isReadOnly) return 'default';\n    return 'pointer';\n  }};\n  position: relative;\n\n  &:focus-within ${LabelTextWrapper} {\n    box-shadow: 0 0 0 2px ${designTokens.borderColorForInputWhenFocused};\n  }\n\n  &:hover ${CheckboxIconWrapper} {\n    background-color: ${(props) =>\n      props.isDisabled || props.isReadOnly\n        ? 'unset'\n        : designTokens.backgroundColorForCheckboxInputWhenHovered};\n  }\n`;\n\nconst CheckboxInput = (props: TCheckboxProps) => {\n  // We generate an id in case no id is provided by the parent to attach the\n  // label to the input component.\n  const id = props.id || sequentialId();\n  return (\n    <Label\n      htmlFor={id}\n      hasError={props.hasError}\n      isDisabled={props.isDisabled}\n      isReadOnly={props.isReadOnly}\n      isChecked={props.isChecked}\n      isHovered={props.isHovered}\n      isIndeterminate={props.isIndeterminate}\n    >\n      <Checkbox {...props} id={id} />\n      <CheckboxIcon\n        hasError={props.hasError}\n        isDisabled={props.isDisabled}\n        isReadOnly={props.isReadOnly}\n        isChecked={props.isChecked}\n        isHovered={props.isHovered}\n        isIndeterminate={props.isIndeterminate}\n      />\n      {props.children && (\n        <LabelTextWrapper\n          hasError={props.hasError}\n          isDisabled={props.isDisabled}\n          isReadOnly={props.isReadOnly}\n          isChecked={props.isChecked}\n          isHovered={props.isHovered}\n          isIndeterminate={props.isIndeterminate}\n          // To allow focusing the Label in readOnly mode, because the checkbox gets disabled and therefore unfocusable\n          tabIndex={props.isReadOnly ? 0 : -1}\n        >\n          {props.children}\n        </LabelTextWrapper>\n      )}\n    </Label>\n  );\n};\n\nCheckboxInput.displayName = 'CheckboxInput';\nCheckboxInput.defaultProps = defaultProps;\n\nexport default CheckboxInput;\n"]} */"));
359
364
  const CheckboxInput = props => {
360
365
  // We generate an id in case no id is provided by the parent to attach the
361
366
  // label to the input component.
@@ -409,6 +414,6 @@ CheckboxInput.defaultProps = defaultProps;
409
414
  var CheckboxInput$1 = CheckboxInput;
410
415
 
411
416
  // NOTE: This string will be replaced on build time with the package version.
412
- var version = "18.4.0";
417
+ var version = "19.0.0";
413
418
 
414
419
  export { CheckboxInput$1 as default, version };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/checkbox-input",
3
3
  "description": "An input component that works as checkbox input.",
4
- "version": "18.4.0",
4
+ "version": "19.0.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -24,11 +24,11 @@
24
24
  "dependencies": {
25
25
  "@babel/runtime": "^7.20.13",
26
26
  "@babel/runtime-corejs3": "^7.20.13",
27
- "@commercetools-uikit/design-system": "18.4.0",
28
- "@commercetools-uikit/icons": "18.4.0",
29
- "@commercetools-uikit/input-utils": "18.4.0",
30
- "@commercetools-uikit/select-utils": "18.4.0",
31
- "@commercetools-uikit/utils": "18.4.0",
27
+ "@commercetools-uikit/design-system": "19.0.0",
28
+ "@commercetools-uikit/icons": "19.0.0",
29
+ "@commercetools-uikit/input-utils": "19.0.0",
30
+ "@commercetools-uikit/select-utils": "19.0.0",
31
+ "@commercetools-uikit/utils": "19.0.0",
32
32
  "@emotion/react": "^11.10.5",
33
33
  "@emotion/styled": "^11.10.5",
34
34
  "prop-types": "15.8.1",