@commercetools-uikit/checkbox-input 16.5.0 → 16.6.1
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.
|
@@ -327,13 +327,13 @@ const LabelTextWrapper = /*#__PURE__*/_styled__default["default"]("div", process
|
|
|
327
327
|
} : {
|
|
328
328
|
target: "e6nn4mw2",
|
|
329
329
|
label: "LabelTextWrapper"
|
|
330
|
-
})("margin-left:calc(\n ", designSystem.designTokens.spacing20, " - ", designSystem.designTokens.borderWidthForCheckboxInputIcon, "\n );outline:none;border-radius:", designSystem.designTokens.borderRadiusForTag, ";font-size:", designSystem.designTokens.fontSizeForTextAsBody, ";line-height:", designSystem.designTokens.lineHeightForTextAsBody, ";font-weight:", designSystem.designTokens.fontWeightForTextAsBody, ";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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
330
|
+
})("margin-left:calc(\n ", designSystem.designTokens.spacing20, " - ", designSystem.designTokens.borderWidthForCheckboxInputIcon, "\n );outline:none;border-radius:", designSystem.designTokens.borderRadiusForTag, ";font-size:", designSystem.designTokens.fontSizeForTextAsBody, ";line-height:", designSystem.designTokens.lineHeightForTextAsBody, ";font-weight:", designSystem.designTokens.fontWeightForTextAsBody, ";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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
331
331
|
const CheckboxIconWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
332
332
|
target: "e6nn4mw1"
|
|
333
333
|
} : {
|
|
334
334
|
target: "e6nn4mw1",
|
|
335
335
|
label: "CheckboxIconWrapper"
|
|
336
|
-
})("width:", props => props.width, ";height:", props => props.height, ";display:flex;align-items:center;justify-content:center;border-radius:", designSystem.designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/react.css("background-color:", designSystem.designTokens.backgroundColorForCheckboxInputIconWhenHovered, ";" + (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":"AAsJW","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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":"AA4IiE","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
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.backgroundColorForCheckboxInputIconWhenHovered, ";" + (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":"AAuJW","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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":"AA4IiE","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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
337
|
const CheckboxIcon = props => {
|
|
338
338
|
var _context;
|
|
339
339
|
const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;
|
|
@@ -343,7 +343,7 @@ const CheckboxIcon = props => {
|
|
|
343
343
|
height: "26px",
|
|
344
344
|
isHovered: canForcedHoverEffect,
|
|
345
345
|
children: jsxRuntime.jsx("div", {
|
|
346
|
-
css: _filterInstanceProperty__default["default"](_context = [/*#__PURE__*/react.css("border-width:", designSystem.designTokens.borderWidthForCheckboxInputIcon, ";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":"AAyKa","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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),
|
|
346
|
+
css: _filterInstanceProperty__default["default"](_context = [/*#__PURE__*/react.css("border-width:", designSystem.designTokens.borderWidthForCheckboxInputIcon, ";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":"AA0Ka","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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),
|
|
347
347
|
children: (() => {
|
|
348
348
|
if (props.isIndeterminate) return jsxRuntime.jsx(IndeterminateIcon$1, {
|
|
349
349
|
color: "surface",
|
|
@@ -367,7 +367,7 @@ const Label = /*#__PURE__*/_styled__default["default"]("label", process.env.NODE
|
|
|
367
367
|
if (props.isDisabled) return 'not-allowed';
|
|
368
368
|
if (props.isReadOnly) return 'default';
|
|
369
369
|
return 'pointer';
|
|
370
|
-
}, ";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.backgroundColorForCheckboxInputIconWhenHovered, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAwMuC","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
370
|
+
}, ";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.backgroundColorForCheckboxInputIconWhenHovered, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAyMuC","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
371
371
|
const CheckboxInput = props => {
|
|
372
372
|
// We generate an id in case no id is provided by the parent to attach the
|
|
373
373
|
// label to the input component.
|
|
@@ -421,7 +421,7 @@ CheckboxInput.defaultProps = defaultProps;
|
|
|
421
421
|
var CheckboxInput$1 = CheckboxInput;
|
|
422
422
|
|
|
423
423
|
// NOTE: This string will be replaced on build time with the package version.
|
|
424
|
-
var version = "16.
|
|
424
|
+
var version = "16.6.1";
|
|
425
425
|
|
|
426
426
|
exports["default"] = CheckboxInput$1;
|
|
427
427
|
exports.version = version;
|
|
@@ -324,7 +324,7 @@ const LabelTextWrapper = /*#__PURE__*/_styled__default["default"]("div", {
|
|
|
324
324
|
} )("margin-left:calc(\n ", designSystem.designTokens.spacing20, " - ", designSystem.designTokens.borderWidthForCheckboxInputIcon, "\n );outline:none;border-radius:", designSystem.designTokens.borderRadiusForTag, ";font-size:", designSystem.designTokens.fontSizeForTextAsBody, ";line-height:", designSystem.designTokens.lineHeightForTextAsBody, ";font-weight:", designSystem.designTokens.fontWeightForTextAsBody, ";color:", props => getTextColor(props), ";" + ("" ));
|
|
325
325
|
const CheckboxIconWrapper = /*#__PURE__*/_styled__default["default"]("div", {
|
|
326
326
|
target: "e6nn4mw1"
|
|
327
|
-
} )("width:", props => props.width, ";height:", props => props.height, ";display:flex;align-items:center;justify-content:center;border-radius:", designSystem.designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/react.css("background-color:", designSystem.designTokens.backgroundColorForCheckboxInputIconWhenHovered, ";" + ("" ), "" ) : '', ";" + ("" ));
|
|
327
|
+
} )("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.backgroundColorForCheckboxInputIconWhenHovered, ";" + ("" ), "" ) : '', ";" + ("" ));
|
|
328
328
|
const CheckboxIcon = props => {
|
|
329
329
|
var _context;
|
|
330
330
|
const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;
|
|
@@ -397,7 +397,7 @@ CheckboxInput.defaultProps = defaultProps;
|
|
|
397
397
|
var CheckboxInput$1 = CheckboxInput;
|
|
398
398
|
|
|
399
399
|
// NOTE: This string will be replaced on build time with the package version.
|
|
400
|
-
var version = "16.
|
|
400
|
+
var version = "16.6.1";
|
|
401
401
|
|
|
402
402
|
exports["default"] = CheckboxInput$1;
|
|
403
403
|
exports.version = version;
|
|
@@ -309,13 +309,13 @@ const LabelTextWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "p
|
|
|
309
309
|
} : {
|
|
310
310
|
target: "e6nn4mw2",
|
|
311
311
|
label: "LabelTextWrapper"
|
|
312
|
-
})("margin-left:calc(\n ", designTokens.spacing20, " - ", designTokens.borderWidthForCheckboxInputIcon, "\n );outline:none;border-radius:", designTokens.borderRadiusForTag, ";font-size:", designTokens.fontSizeForTextAsBody, ";line-height:", designTokens.lineHeightForTextAsBody, ";font-weight:", designTokens.fontWeightForTextAsBody, ";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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
312
|
+
})("margin-left:calc(\n ", designTokens.spacing20, " - ", designTokens.borderWidthForCheckboxInputIcon, "\n );outline:none;border-radius:", designTokens.borderRadiusForTag, ";font-size:", designTokens.fontSizeForTextAsBody, ";line-height:", designTokens.lineHeightForTextAsBody, ";font-weight:", designTokens.fontWeightForTextAsBody, ";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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
313
313
|
const CheckboxIconWrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
314
314
|
target: "e6nn4mw1"
|
|
315
315
|
} : {
|
|
316
316
|
target: "e6nn4mw1",
|
|
317
317
|
label: "CheckboxIconWrapper"
|
|
318
|
-
})("width:", props => props.width, ";height:", props => props.height, ";display:flex;align-items:center;justify-content:center;border-radius:", designTokens.borderRadius6, ";", props => props.isHovered ? /*#__PURE__*/css("background-color:", designTokens.backgroundColorForCheckboxInputIconWhenHovered, ";" + (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":"AAsJW","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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":"AA4IiE","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
318
|
+
})("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.backgroundColorForCheckboxInputIconWhenHovered, ";" + (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":"AAuJW","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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":"AA4IiE","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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
319
|
const CheckboxIcon = props => {
|
|
320
320
|
var _context;
|
|
321
321
|
const isDisabledOrReadOnlyState = props.isDisabled || props.isReadOnly;
|
|
@@ -325,7 +325,7 @@ const CheckboxIcon = props => {
|
|
|
325
325
|
height: "26px",
|
|
326
326
|
isHovered: canForcedHoverEffect,
|
|
327
327
|
children: jsx("div", {
|
|
328
|
-
css: _filterInstanceProperty(_context = [/*#__PURE__*/css("border-width:", designTokens.borderWidthForCheckboxInputIcon, ";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":"AAyKa","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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),
|
|
328
|
+
css: _filterInstanceProperty(_context = [/*#__PURE__*/css("border-width:", designTokens.borderWidthForCheckboxInputIcon, ";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":"AA0Ka","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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),
|
|
329
329
|
children: (() => {
|
|
330
330
|
if (props.isIndeterminate) return jsx(IndeterminateIcon$1, {
|
|
331
331
|
color: "surface",
|
|
@@ -349,7 +349,7 @@ const Label = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "production
|
|
|
349
349
|
if (props.isDisabled) return 'not-allowed';
|
|
350
350
|
if (props.isReadOnly) return 'default';
|
|
351
351
|
return 'pointer';
|
|
352
|
-
}, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designTokens.backgroundColorForCheckboxInputIconWhenHovered, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAwMuC","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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  align-items: center;\n  justify-content: center;\n  border-radius: ${designTokens.borderRadius6};\n\n  ${(props) =>\n    props.isHovered\n      ? css`\n          background-color: ${designTokens.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
352
|
+
}, ";position:relative;&:focus-within ", LabelTextWrapper, "{box-shadow:0 0 0 2px ", designTokens.borderColorForInputWhenFocused, ";}&:hover ", CheckboxIconWrapper, "{background-color:", props => props.isDisabled || props.isReadOnly ? 'unset' : designTokens.backgroundColorForCheckboxInputIconWhenHovered, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["checkbox-input.tsx"],"names":[],"mappings":"AAyMuC","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.borderColorForCheckboxInputIconWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.borderColorForCheckboxInputIconWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.borderColorForCheckboxInputIconWhenReadonly;\n  }\n  return designTokens.borderColorForCheckboxInputIcon;\n};\n\nconst getBackgroundColor = (props: TLabelProps) => {\n  if (props.isChecked || props.isIndeterminate) {\n    if (props.hasError) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenError;\n    }\n    if (props.isDisabled) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenDisabled;\n    }\n    if (props.isReadOnly) {\n      return designTokens.backgroundColorForCheckboxInputIconWhenReadonly;\n    }\n    return designTokens.backgroundColorForCheckboxInputIcon;\n  }\n  return designTokens.colorSurface;\n};\n\nconst getTextColor = (props: TLabelProps) => {\n  if (props.hasError) {\n    return designTokens.fontColorForCheckboxInputLabelWhenError;\n  }\n  if (props.isDisabled) {\n    return designTokens.fontColorForCheckboxInputLabelWhenDisabled;\n  }\n  if (props.isReadOnly) {\n    return designTokens.fontColorForCheckboxInputLabelWhenReadonly;\n  }\n  return designTokens.fontColorForCheckboxInputLabel;\n};\n\nconst LabelTextWrapper = styled.div<TLabelProps>`\n  margin-left: calc(\n    ${designTokens.spacing20} - ${designTokens.borderWidthForCheckboxInputIcon}\n  );\n  outline: none;\n  border-radius: ${designTokens.borderRadiusForTag};\n\n  font-size: ${designTokens.fontSizeForTextAsBody};\n  line-height: ${designTokens.lineHeightForTextAsBody};\n  font-weight: ${designTokens.fontWeightForTextAsBody};\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.backgroundColorForCheckboxInputIconWhenHovered};\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.borderWidthForCheckboxInputIcon};\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.backgroundColorForCheckboxInputIconWhenHovered};\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"]} */"));
|
|
353
353
|
const CheckboxInput = props => {
|
|
354
354
|
// We generate an id in case no id is provided by the parent to attach the
|
|
355
355
|
// label to the input component.
|
|
@@ -403,6 +403,6 @@ CheckboxInput.defaultProps = defaultProps;
|
|
|
403
403
|
var CheckboxInput$1 = CheckboxInput;
|
|
404
404
|
|
|
405
405
|
// NOTE: This string will be replaced on build time with the package version.
|
|
406
|
-
var version = "16.
|
|
406
|
+
var version = "16.6.1";
|
|
407
407
|
|
|
408
408
|
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": "16.
|
|
4
|
+
"version": "16.6.1",
|
|
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": "16.
|
|
28
|
-
"@commercetools-uikit/icons": "16.
|
|
29
|
-
"@commercetools-uikit/input-utils": "16.
|
|
30
|
-
"@commercetools-uikit/select-utils": "16.
|
|
31
|
-
"@commercetools-uikit/utils": "16.
|
|
27
|
+
"@commercetools-uikit/design-system": "16.6.1",
|
|
28
|
+
"@commercetools-uikit/icons": "16.6.1",
|
|
29
|
+
"@commercetools-uikit/input-utils": "16.6.1",
|
|
30
|
+
"@commercetools-uikit/select-utils": "16.6.1",
|
|
31
|
+
"@commercetools-uikit/utils": "16.6.1",
|
|
32
32
|
"@emotion/react": "^11.10.5",
|
|
33
33
|
"@emotion/styled": "^11.10.5",
|
|
34
34
|
"prop-types": "15.8.1",
|