@amboss/design-system 3.9.5 → 3.9.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/Button/Button.js +1 -1
- package/build/cjs/components/EntityList/BaseEntityList.js +1 -1
- package/build/cjs/components/EntityList/EntityItemBody.js +1 -1
- package/build/cjs/components/EntityList/EntityListItem.js +1 -1
- package/build/cjs/components/Form/Combobox/OptionsList.js +1 -1
- package/build/cjs/components/VirtualScrollList/VirtualScrollList.d.ts +2 -1
- package/build/cjs/components/VirtualScrollList/VirtualScrollList.js +1 -1
- package/build/esm/components/Button/Button.js +1 -1
- package/build/esm/components/EntityList/BaseEntityList.js +1 -1
- package/build/esm/components/EntityList/EntityItemBody.js +1 -1
- package/build/esm/components/EntityList/EntityListItem.js +1 -1
- package/build/esm/components/Form/Combobox/OptionsList.js +1 -1
- package/build/esm/components/VirtualScrollList/VirtualScrollList.d.ts +2 -1
- package/build/esm/components/VirtualScrollList/VirtualScrollList.js +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Button",{enumerable:!0,get:function(){return Button}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Inline=require("../Inline/Inline"),_Icon=require("../Icon/Icon"),StyledButton=(0,_styled.default)("button",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"erh6bp80",label:"StyledButton"})(({theme,fullWidth,destructive,size,squareCorners,variant,disabled,loading})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",border:0,margin:0,textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,cursor:"pointer",...disabled&&{...!loading&&{opacity:theme.variables.opacity.disabled},cursor:"not-allowed"},..."s"===size&&{padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`},..."m"===size&&{padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},..."l"===size&&{padding:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`},..."primary"===variant&&{backgroundColor:destructive?theme.values.color.background.error.default:theme.values.color.background.accent.default,color:theme.values.color.text.onAccent.default,...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.background.error.hover:theme.values.color.background.accent.hover},"&:active":{backgroundColor:destructive?theme.values.color.background.error.active:theme.values.color.background.accent.active}},...loading&&{color:theme.values.color.text.onAccent.disabled,backgroundColor:destructive?theme.values.color.background.error.disabled:theme.values.color.background.accent.disabled}},..."secondary"===variant&&{border:"1px solid",backgroundColor:theme.values.color.background.transparent.default,borderColor:theme.values.color.border.primary.default,color:theme.values.color.text.secondary.default,...!disabled&&{"&:hover":{borderColor:theme.values.color.border.primary.hover,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active}},...loading&&{borderColor:theme.values.color.border.primary.disabled},..."s"===size&&{padding:`${parseInt(theme.variables.size.spacing.xs,10)-1}px ${parseInt(theme.variables.size.spacing.m,10)-1}px`},..."m"===size&&{padding:`${parseInt(theme.variables.size.spacing.s,10)-1}px ${parseInt(theme.variables.size.spacing.l,10)-1}px`},..."l"===size&&{padding:`${parseInt(theme.variables.size.spacing.m,10)-1}px ${parseInt(theme.variables.size.spacing.xl,10)-1}px`}},..."tertiary"===variant&&{color:destructive?theme.values.color.text.error.default:theme.values.color.text.secondary.default,backgroundColor:theme.values.color.background.transparent.default,fontSize:theme.variables.size.font.xs,lineHeight:theme.variables.size.lineHeight.m,letterSpacing:theme.variables.size.letterSpacing.s,textTransform:"uppercase",...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.hover:theme.values.color.background.transparent.hover},"&:active":{color:destructive?theme.values.color.text.error.default:theme.values.color.text.primary.default,backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.active:theme.values.color.background.transparent.active}},..."s"===size&&{padding:theme.variables.size.spacing.xs},..."m"===size&&{padding:theme.variables.size.spacing.s},..."l"===size&&{padding:theme.variables.size.spacing.m}},...fullWidth&&{width:"100%"},...squareCorners&&"boolean"==typeof squareCorners?{borderRadius:0}:squareCorners&&"boolean"!=typeof squareCorners&&{...squareCorners.reduce((prev,actual)=>({...prev,[`border${actual}Radius`]:0}),{})}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAqBqB"} */"),StyledInner=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"erh6bp81",label:"StyledInner"})(({loading})=>loading&&{color:"transparent"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiLoB"} */"),StyledLoaderWrap=(0,_styled.default)("div",{target:"erh6bp82",label:"StyledLoaderWrap"})(()=>({position:"relative",width:"100%",height:"100%",top:0,left:0,display:"flex",justifyContent:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0LyB"} */"),rotation=(0,_react1.keyframes)({from:{transform:"rotate(0deg)"},to:{transform:"rotate(360deg)"}},"label:rotation","/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuMiB"} */"),StyledLoader=(0,_styled.default)("div",{target:"erh6bp83",label:"StyledLoader"})(()=>({position:"absolute",animation:`${rotation} 1s infinite linear`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgNqB"} */"),Button=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,ariaAttributes,as,children,disabled=!1,fullWidth=!1,destructive=!1,leftIcon,loading=!1,onBlur,onClick,onFocus,privateProps={squareCorners:!1},rightIcon,size="m",type="button",variant="primary",...rest},ref)=>{let{squareCorners,alignItems,rightIconVariant,rightIconColor}=privateProps,handleClick=(0,_react.useCallback)(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]),rightIconElm=rightIcon?_react.default.createElement(_Icon.Icon,{size:"s",name:rightIcon,...rightIconVariant&&!rightIconColor&&{variant:rightIconVariant},...rightIconColor&&{color:rightIconColor},"data-testid":rightIcon,"data-e2e-test-id":rightIcon,"aria-hidden":!0}):null;return _react.default.createElement(StyledButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Button",as:as,disabled:disabled||loading,loading:loading,type:as&&"button"!==as?void 0:type,fullWidth:fullWidth,destructive:destructive,squareCorners:squareCorners,variant:variant,size:size,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},loading&&_react.default.createElement(StyledLoaderWrap,null,_react.default.createElement(StyledLoader,null,_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:"loader",color:function(variant,destructive){switch(variant){case"primary":return destructive?"error":"accent";case"secondary":return"primary";default:return destructive?"error":variant}}(variant,destructive),"data-testid":"loader","data-e2e-test-id":"loader"}))),_react.default.createElement(StyledInner,{loading:loading},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:alignItems||"center",space:"xxs",noWrap:!0},leftIcon&&_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:leftIcon,"data-testid":leftIcon,"data-e2e-test-id":leftIcon}),children,rightIconElm)))});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Button",{enumerable:!0,get:function(){return Button}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Inline=require("../Inline/Inline"),_Icon=require("../Icon/Icon"),StyledButton=(0,_styled.default)("button",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"egiie9d0",label:"StyledButton"})(({theme,fullWidth,destructive,size,squareCorners,variant,disabled,loading})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",border:0,margin:0,textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,cursor:"pointer",...disabled&&{...!loading&&{opacity:theme.variables.opacity.disabled},cursor:"not-allowed"},..."s"===size&&{padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`},..."m"===size&&{padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},..."l"===size&&{padding:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`},..."primary"===variant&&{backgroundColor:destructive?theme.values.color.background.error.default:theme.values.color.background.accent.default,color:theme.values.color.text.onAccent.default,...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.background.error.hover:theme.values.color.background.accent.hover},"&:active":{backgroundColor:destructive?theme.values.color.background.error.active:theme.values.color.background.accent.active}},...loading&&{color:theme.values.color.text.onAccent.disabled,backgroundColor:destructive?theme.values.color.background.error.disabled:theme.values.color.background.accent.disabled}},..."secondary"===variant&&{border:"1px solid",backgroundColor:theme.values.color.background.transparent.default,borderColor:theme.values.color.border.primary.default,color:theme.values.color.text.secondary.default,...!disabled&&{"&:hover":{borderColor:theme.values.color.border.primary.hover,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active}},...loading&&{borderColor:theme.values.color.border.primary.disabled},..."s"===size&&{padding:`${parseInt(theme.variables.size.spacing.xs,10)-1}px ${parseInt(theme.variables.size.spacing.m,10)-1}px`},..."m"===size&&{padding:`${parseInt(theme.variables.size.spacing.s,10)-1}px ${parseInt(theme.variables.size.spacing.l,10)-1}px`},..."l"===size&&{padding:`${parseInt(theme.variables.size.spacing.m,10)-1}px ${parseInt(theme.variables.size.spacing.xl,10)-1}px`}},..."tertiary"===variant&&{color:destructive?theme.values.color.text.error.default:theme.values.color.text.secondary.default,backgroundColor:theme.values.color.background.transparent.default,fontSize:theme.variables.size.font.xs,lineHeight:theme.variables.size.lineHeight.m,letterSpacing:theme.variables.size.letterSpacing.s,textTransform:"uppercase",...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.hover:theme.values.color.background.transparent.hover},"&:active":{color:destructive?theme.values.color.text.error.default:theme.values.color.text.primary.default,backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.active:theme.values.color.background.transparent.active}},..."s"===size&&{padding:theme.variables.size.spacing.xs},..."m"===size&&{padding:theme.variables.size.spacing.s},..."l"===size&&{padding:theme.variables.size.spacing.m}},...fullWidth&&{width:"100%"},...squareCorners&&"boolean"==typeof squareCorners?{borderRadius:0}:squareCorners&&"boolean"!=typeof squareCorners&&{...squareCorners.reduce((prev,actual)=>({...prev,[`border${actual}Radius`]:0}),{})}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAqBqB"} */"),StyledInner=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"egiie9d1",label:"StyledInner"})(({loading})=>loading&&{color:"transparent"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiLoB"} */"),StyledLoaderWrap=(0,_styled.default)("div",{target:"egiie9d2",label:"StyledLoaderWrap"})(()=>({position:"relative",width:"100%",height:"100%",top:0,left:0,display:"flex",justifyContent:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA0LyB"} */"),rotation=(0,_react1.keyframes)({from:{transform:"rotate(0deg)"},to:{transform:"rotate(360deg)"}},"label:rotation","/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuMiB"} */"),StyledLoader=(0,_styled.default)("div",{target:"egiie9d3",label:"StyledLoader"})(()=>({position:"absolute",animation:`${rotation} 1s infinite linear`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAgNqB"} */"),Button=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,ariaAttributes,as,children,disabled=!1,fullWidth=!1,destructive=!1,leftIcon,loading=!1,onBlur,onClick,onFocus,privateProps={squareCorners:!1},rightIcon,size="m",type="button",variant="primary",...rest},ref)=>{let{squareCorners,alignItems,rightIconVariant,rightIconColor}=privateProps,handleClick=(0,_react.useCallback)(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]),rightIconElm=rightIcon?_react.default.createElement(_Icon.Icon,{size:"s",name:rightIcon,...rightIconVariant&&!rightIconColor&&{variant:rightIconVariant},...rightIconColor&&{color:rightIconColor},"data-testid":rightIcon,"data-e2e-test-id":rightIcon,"aria-hidden":!0}):null;return _react.default.createElement(StyledButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Button",as:as,disabled:disabled||loading,loading:loading,type:as&&"button"!==as?void 0:type,fullWidth:fullWidth,destructive:destructive,squareCorners:squareCorners,variant:variant,size:size,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},loading&&_react.default.createElement(StyledLoaderWrap,null,_react.default.createElement(StyledLoader,null,_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:"loader",color:function(variant,destructive){switch(variant){case"primary":return destructive?"error":"accent";case"secondary":return"primary";default:return destructive?"error":variant}}(variant,destructive),"data-testid":"loader","data-e2e-test-id":"loader"}))),_react.default.createElement(StyledInner,{loading:loading},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:alignItems||"center",space:"s"===size?"xxs":"xs",noWrap:!0},leftIcon&&_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:leftIcon,"data-testid":leftIcon,"data-e2e-test-id":leftIcon}),children,rightIconElm)))});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BaseEntityList",{enumerable:!0,get:function(){return BaseEntityList}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_styledcomponents=require("./styled-components"),_useKeyboard=require("../../shared/useKeyboard"),_Icon=require("../Icon/Icon"),_EntityListItem=require("./EntityListItem"),StyledMinHeightCell=(0,_styled.default)("div",{target:"er6regd0",label:"StyledMinHeightCell"})(({theme,textSize})=>({minHeight:"s"===textSize?`calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`:theme.variables.size.spacing.l,display:"flex",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/EntityList/BaseEntityList.tsx","sources":["src/components/EntityList/BaseEntityList.tsx"],"sourcesContent":["import React, {\n  useRef,\n  useState,\n  useEffect,\n  useMemo,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { StyledList } from \"./styled-components\";\nimport type { EntityListProps, ListNode, TextSizeProps } from \"./types\";\nimport { useKeyboard } from \"../../shared/useKeyboard\";\nimport { Icon } from \"../Icon/Icon\";\nimport { EntityListItem } from \"./EntityListItem\";\n\n// This minHeight is needed for align small icons in the middle of 1 row text,\n// but it should stay at the top if there is multiline text\nconst StyledMinHeightCell = styled.div<TextSizeProps>(\n  ({ theme, textSize }) => ({\n    minHeight:\n      textSize === \"s\"\n        ? `calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`\n        : theme.variables.size.spacing.l,\n    display: \"flex\",\n    alignItems: \"center\",\n  })\n);\n\nconst findEnabledItemIndex = (\n  items: ListNode[],\n  startIndex: number,\n  direction = \"next\"\n): number => {\n  if (direction === \"next\") {\n    for (let i = startIndex + 1; i < items.length; i += 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  } else if (direction === \"previous\") {\n    for (let i = startIndex - 1; i >= 0; i -= 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  }\n  return startIndex;\n};\n\nexport function BaseEntityList({\n  data,\n  size = \"m\",\n  onClick,\n  isSelectable,\n  selectedIds,\n  onSelectionChange,\n  renderRightContent,\n  getLeftIconProps,\n  hideBorder,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: EntityListProps): React.ReactElement {\n  const selectedIdsSet = useMemo(() => new Set(selectedIds), [selectedIds]);\n  const [isKeyboardFocus, setIsKeyboradFocus] = useState<boolean>(false);\n  const [selectedIndex, setSelectedIndex] = useState<number>(() =>\n    isSelectable || onClick ? findEnabledItemIndex(data, -1) : -1\n  );\n  const refList = useRef<HTMLUListElement>(null);\n  useKeyboard(\n    {\n      ArrowDown: () => {\n        setIsKeyboradFocus(true);\n        const nextIndex = findEnabledItemIndex(data, selectedIndex);\n        setSelectedIndex(nextIndex);\n      },\n      ArrowUp: () => {\n        setIsKeyboradFocus(true);\n        const prevIndex = findEnabledItemIndex(data, selectedIndex, \"previous\");\n        setSelectedIndex(prevIndex);\n      },\n    },\n    refList,\n    selectedIndex !== -1\n  );\n\n  useEffect(() => {\n    if (refList && refList.current && isKeyboardFocus && selectedIndex >= 0) {\n      const buttons = refList.current.querySelectorAll('div[role=\"button\"]');\n\n      (buttons[Math.abs(selectedIndex) % buttons.length] as HTMLElement).focus({\n        preventScroll: true,\n      });\n    }\n  }, [selectedIndex, isKeyboardFocus]);\n\n  const handleOnClick = useCallback(\n    (item: ListNode) => {\n      const { id } = item;\n\n      // Handle checkbox change\n      if (isSelectable) {\n        if (selectedIdsSet.has(id)) {\n          selectedIdsSet.delete(id);\n        } else {\n          selectedIdsSet.add(id);\n        }\n        onSelectionChange?.(Array.from(selectedIdsSet));\n      }\n\n      onClick?.(item);\n    },\n    [selectedIdsSet, onSelectionChange, onClick, isSelectable]\n  );\n\n  const handleBlur = useCallback(() => {\n    // Use setTimeout to wait for focus to fully propagate\n    setTimeout(() => {\n      if (\n        refList.current &&\n        !refList.current.contains(document.activeElement)\n      ) {\n        setIsKeyboradFocus(false);\n        setSelectedIndex(() => findEnabledItemIndex(data, -1));\n      }\n    }, 0);\n  }, [refList, setSelectedIndex, data]);\n\n  return (\n    <StyledList\n      ref={refList}\n      size={size}\n      data-e2e-test-id={dataE2eTestId}\n      onBlur={handleBlur}\n      data-ds-id=\"EntityList\"\n      role=\"list\"\n    >\n      {data.map((item, i) => {\n        const tabIndex = i === selectedIndex ? 0 : -1;\n\n        return (\n          <EntityListItem\n            key={item.id}\n            aria-label={item[\"aria-label\"] || item.label}\n            size={size}\n            hideBorder={hideBorder || i === data.length - 1}\n            isActive={item.isActive || (isKeyboardFocus && selectedIndex === i)}\n            isDisabled={item.isDisabled}\n            isClickable={Boolean(onClick || selectedIds)}\n            description={item.description}\n            onKeyDown={() => handleOnClick(item)}\n            tabIndex={tabIndex}\n            onFocus={() => {\n              if (onClick || isSelectable) {\n                setSelectedIndex(i);\n                setIsKeyboradFocus(true);\n              }\n            }}\n            onClick={() => {\n              setIsKeyboradFocus(false);\n              handleOnClick(item);\n            }}\n            checkboxProps={\n              isSelectable && {\n                name: \"list-checkbox\",\n                size: \"s\",\n                onChange: () => handleOnClick(item),\n                checked: selectedIdsSet.has(item.id),\n              }\n            }\n            renderLabel={() => item.label}\n            renderLeft={\n              getLeftIconProps\n                ? ({ textSize }) => (\n                    <Icon\n                      /* eslint-disable-next-line react/jsx-props-no-spreading */\n                      {...getLeftIconProps(item)}\n                      size={textSize}\n                    />\n                  )\n                : null\n            }\n            renderRight={({ actionSize, textSize }) =>\n              renderRightContent ? (\n                <StyledMinHeightCell textSize={textSize}>\n                  {renderRightContent({ textSize, actionSize, ...item })}\n                </StyledMinHeightCell>\n              ) : null\n            }\n          />\n        );\n      })}\n    </StyledList>\n  );\n}\n"],"names":[],"mappings":"AAgB4B"} */"),findEnabledItemIndex=(items,startIndex,direction="next")=>{if("next"===direction){for(let i=startIndex+1;i<items.length;i+=1)if(!items[i].isDisabled)return i}else if("previous"===direction){for(let i=startIndex-1;i>=0;i-=1)if(!items[i].isDisabled)return i}return startIndex};function BaseEntityList({data,size="m",onClick,isSelectable,selectedIds,onSelectionChange,renderRightContent,getLeftIconProps,hideBorder,"data-e2e-test-id":dataE2eTestId}){let selectedIdsSet=(0,_react.useMemo)(()=>new Set(selectedIds),[selectedIds]),[isKeyboardFocus,setIsKeyboradFocus]=(0,_react.useState)(!1),[selectedIndex,setSelectedIndex]=(0,_react.useState)(()=>isSelectable||onClick?findEnabledItemIndex(data,-1):-1),refList=(0,_react.useRef)(null);(0,_useKeyboard.useKeyboard)({ArrowDown:()=>{setIsKeyboradFocus(!0),setSelectedIndex(findEnabledItemIndex(data,selectedIndex))},ArrowUp:()=>{setIsKeyboradFocus(!0),setSelectedIndex(findEnabledItemIndex(data,selectedIndex,"previous"))}},refList,-1!==selectedIndex),(0,_react.useEffect)(()=>{if(refList&&refList.current&&isKeyboardFocus&&selectedIndex>=0){let buttons=refList.current.querySelectorAll('div[role="button"]');buttons[Math.abs(selectedIndex)%buttons.length].focus({preventScroll:!0})}},[selectedIndex,isKeyboardFocus]);let handleOnClick=(0,_react.useCallback)(item=>{let{id}=item;isSelectable&&(selectedIdsSet.has(id)?selectedIdsSet.delete(id):selectedIdsSet.add(id),onSelectionChange?.(Array.from(selectedIdsSet))),onClick?.(item)},[selectedIdsSet,onSelectionChange,onClick,isSelectable]),handleBlur=(0,_react.useCallback)(()=>{setTimeout(()=>{refList.current&&!refList.current.contains(document.activeElement)&&(setIsKeyboradFocus(!1),setSelectedIndex(()=>findEnabledItemIndex(data,-1)))},0)},[refList,setSelectedIndex,data]);return _react.default.createElement(_styledcomponents.StyledList,{ref:refList,size:size,"data-e2e-test-id":dataE2eTestId,onBlur:handleBlur,"data-ds-id":"EntityList",role:"list"},data.map((item,i)=>{let tabIndex=i===selectedIndex?0:-1;return _react.default.createElement(_EntityListItem.EntityListItem,{key:item.id,"aria-label":item["aria-label"]||item.label,size:size,hideBorder:hideBorder||i===data.length-1,isActive:item.isActive||isKeyboardFocus&&selectedIndex===i,isDisabled:item.isDisabled,isClickable:!!(onClick||selectedIds),description:item.description,onKeyDown:()=>handleOnClick(item),tabIndex:tabIndex,onFocus:()=>{(onClick||isSelectable)&&(setSelectedIndex(i),setIsKeyboradFocus(!0))},onClick:()=>{setIsKeyboradFocus(!1),handleOnClick(item)},checkboxProps:isSelectable&&{name:"list-checkbox",size:"s",onChange:()=>handleOnClick(item),checked:selectedIdsSet.has(item.id)},renderLabel:()=>item.label,renderLeft:getLeftIconProps?({textSize})=>_react.default.createElement(_Icon.Icon,{...getLeftIconProps(item),size:textSize}):null,renderRight:({actionSize,textSize})=>renderRightContent?_react.default.createElement(StyledMinHeightCell,{textSize:textSize},renderRightContent({textSize,actionSize,...item})):null})}))}
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"BaseEntityList",{enumerable:!0,get:function(){return BaseEntityList}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_styledcomponents=require("./styled-components"),_useKeyboard=require("../../shared/useKeyboard"),_Icon=require("../Icon/Icon"),_EntityListItem=require("./EntityListItem"),StyledMinHeightCell=(0,_styled.default)("div",{target:"eczp0q10",label:"StyledMinHeightCell"})(({theme,textSize})=>({minHeight:"s"===textSize?`calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`:theme.variables.size.spacing.l,display:"flex",alignItems:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/EntityList/BaseEntityList.tsx","sources":["src/components/EntityList/BaseEntityList.tsx"],"sourcesContent":["import React, {\n  useRef,\n  useState,\n  useEffect,\n  useMemo,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { StyledList } from \"./styled-components\";\nimport type { EntityListProps, ListNode, TextSizeProps } from \"./types\";\nimport { useKeyboard } from \"../../shared/useKeyboard\";\nimport { Icon } from \"../Icon/Icon\";\nimport { EntityListItem } from \"./EntityListItem\";\n\n// This minHeight is needed for align small icons in the middle of 1 row text,\n// but it should stay at the top if there is multiline text\nconst StyledMinHeightCell = styled.div<TextSizeProps>(\n  ({ theme, textSize }) => ({\n    minHeight:\n      textSize === \"s\"\n        ? `calc(${theme.variables.size.spacing.m} + ${theme.variables.size.spacing.xxs})`\n        : theme.variables.size.spacing.l,\n    display: \"flex\",\n    alignItems: \"center\",\n  })\n);\n\nconst findEnabledItemIndex = (\n  items: ListNode[],\n  startIndex: number,\n  direction = \"next\"\n): number => {\n  if (direction === \"next\") {\n    for (let i = startIndex + 1; i < items.length; i += 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  } else if (direction === \"previous\") {\n    for (let i = startIndex - 1; i >= 0; i -= 1) {\n      if (!items[i].isDisabled) {\n        return i;\n      }\n    }\n  }\n  return startIndex;\n};\n\nexport function BaseEntityList({\n  data,\n  size = \"m\",\n  onClick,\n  isSelectable,\n  selectedIds,\n  onSelectionChange,\n  renderRightContent,\n  getLeftIconProps,\n  hideBorder,\n  \"data-e2e-test-id\": dataE2eTestId,\n}: EntityListProps): React.ReactElement {\n  const selectedIdsSet = useMemo(() => new Set(selectedIds), [selectedIds]);\n  const [isKeyboardFocus, setIsKeyboardFocus] = useState<boolean>(false);\n  const [selectedIndex, setSelectedIndex] = useState<number>(() =>\n    isSelectable || onClick ? findEnabledItemIndex(data, -1) : -1\n  );\n  const refList = useRef<HTMLUListElement>(null);\n  useKeyboard(\n    {\n      ArrowDown: () => {\n        setIsKeyboardFocus(true);\n        const nextIndex = findEnabledItemIndex(data, selectedIndex);\n        setSelectedIndex(nextIndex);\n      },\n      ArrowUp: () => {\n        setIsKeyboardFocus(true);\n        const prevIndex = findEnabledItemIndex(data, selectedIndex, \"previous\");\n        setSelectedIndex(prevIndex);\n      },\n    },\n    refList,\n    selectedIndex !== -1\n  );\n\n  useEffect(() => {\n    if (refList && refList.current && isKeyboardFocus && selectedIndex >= 0) {\n      const buttons = refList.current.querySelectorAll(\n        'div[data-id=\"list-item\"]'\n      );\n\n      (buttons[Math.abs(selectedIndex) % buttons.length] as HTMLElement).focus({\n        preventScroll: true,\n      });\n    }\n  }, [selectedIndex, isKeyboardFocus]);\n\n  const handleOnClick = useCallback(\n    (item: ListNode) => {\n      const { id } = item;\n\n      // Handle checkbox change\n      if (isSelectable) {\n        if (selectedIdsSet.has(id)) {\n          selectedIdsSet.delete(id);\n        } else {\n          selectedIdsSet.add(id);\n        }\n        onSelectionChange?.(Array.from(selectedIdsSet));\n      }\n\n      onClick?.(item);\n    },\n    [selectedIdsSet, onSelectionChange, onClick, isSelectable]\n  );\n\n  const handleBlur = useCallback(() => {\n    // Use setTimeout to wait for focus to fully propagate\n    setTimeout(() => {\n      if (\n        refList.current &&\n        !refList.current.contains(document.activeElement)\n      ) {\n        setIsKeyboardFocus(false);\n        setSelectedIndex(() => findEnabledItemIndex(data, -1));\n      }\n    }, 0);\n  }, [refList, setSelectedIndex, data]);\n\n  return (\n    <StyledList\n      ref={refList}\n      size={size}\n      data-e2e-test-id={dataE2eTestId}\n      onBlur={handleBlur}\n      data-ds-id=\"EntityList\"\n      role=\"list\"\n    >\n      {data.map((item, i) => {\n        const tabIndex = i === selectedIndex ? 0 : -1;\n\n        return (\n          <EntityListItem\n            key={item.id}\n            aria-label={item[\"aria-label\"] || item.label}\n            size={size}\n            hideBorder={hideBorder || i === data.length - 1}\n            isActive={item.isActive || (isKeyboardFocus && selectedIndex === i)}\n            isDisabled={item.isDisabled}\n            isClickable={Boolean(onClick || selectedIds)}\n            description={item.description}\n            onKeyDown={() => handleOnClick(item)}\n            tabIndex={tabIndex}\n            onFocus={() => {\n              if (onClick || isSelectable) {\n                setSelectedIndex(i);\n                setIsKeyboardFocus(true);\n              }\n            }}\n            onClick={() => {\n              setIsKeyboardFocus(false);\n              handleOnClick(item);\n            }}\n            checkboxProps={\n              isSelectable && {\n                name: \"list-checkbox\",\n                size: \"s\",\n                onChange: () => handleOnClick(item),\n                checked: selectedIdsSet.has(item.id),\n              }\n            }\n            renderLabel={() => item.label}\n            renderLeft={\n              getLeftIconProps\n                ? ({ textSize }) => (\n                    <Icon\n                      /* eslint-disable-next-line react/jsx-props-no-spreading */\n                      {...getLeftIconProps(item)}\n                      size={textSize}\n                    />\n                  )\n                : null\n            }\n            renderRight={({ actionSize, textSize }) =>\n              renderRightContent ? (\n                <StyledMinHeightCell textSize={textSize}>\n                  {renderRightContent({ textSize, actionSize, ...item })}\n                </StyledMinHeightCell>\n              ) : null\n            }\n          />\n        );\n      })}\n    </StyledList>\n  );\n}\n"],"names":[],"mappings":"AAgB4B"} */"),findEnabledItemIndex=(items,startIndex,direction="next")=>{if("next"===direction){for(let i=startIndex+1;i<items.length;i+=1)if(!items[i].isDisabled)return i}else if("previous"===direction){for(let i=startIndex-1;i>=0;i-=1)if(!items[i].isDisabled)return i}return startIndex};function BaseEntityList({data,size="m",onClick,isSelectable,selectedIds,onSelectionChange,renderRightContent,getLeftIconProps,hideBorder,"data-e2e-test-id":dataE2eTestId}){let selectedIdsSet=(0,_react.useMemo)(()=>new Set(selectedIds),[selectedIds]),[isKeyboardFocus,setIsKeyboardFocus]=(0,_react.useState)(!1),[selectedIndex,setSelectedIndex]=(0,_react.useState)(()=>isSelectable||onClick?findEnabledItemIndex(data,-1):-1),refList=(0,_react.useRef)(null);(0,_useKeyboard.useKeyboard)({ArrowDown:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(data,selectedIndex))},ArrowUp:()=>{setIsKeyboardFocus(!0),setSelectedIndex(findEnabledItemIndex(data,selectedIndex,"previous"))}},refList,-1!==selectedIndex),(0,_react.useEffect)(()=>{if(refList&&refList.current&&isKeyboardFocus&&selectedIndex>=0){let buttons=refList.current.querySelectorAll('div[data-id="list-item"]');buttons[Math.abs(selectedIndex)%buttons.length].focus({preventScroll:!0})}},[selectedIndex,isKeyboardFocus]);let handleOnClick=(0,_react.useCallback)(item=>{let{id}=item;isSelectable&&(selectedIdsSet.has(id)?selectedIdsSet.delete(id):selectedIdsSet.add(id),onSelectionChange?.(Array.from(selectedIdsSet))),onClick?.(item)},[selectedIdsSet,onSelectionChange,onClick,isSelectable]),handleBlur=(0,_react.useCallback)(()=>{setTimeout(()=>{refList.current&&!refList.current.contains(document.activeElement)&&(setIsKeyboardFocus(!1),setSelectedIndex(()=>findEnabledItemIndex(data,-1)))},0)},[refList,setSelectedIndex,data]);return _react.default.createElement(_styledcomponents.StyledList,{ref:refList,size:size,"data-e2e-test-id":dataE2eTestId,onBlur:handleBlur,"data-ds-id":"EntityList",role:"list"},data.map((item,i)=>{let tabIndex=i===selectedIndex?0:-1;return _react.default.createElement(_EntityListItem.EntityListItem,{key:item.id,"aria-label":item["aria-label"]||item.label,size:size,hideBorder:hideBorder||i===data.length-1,isActive:item.isActive||isKeyboardFocus&&selectedIndex===i,isDisabled:item.isDisabled,isClickable:!!(onClick||selectedIds),description:item.description,onKeyDown:()=>handleOnClick(item),tabIndex:tabIndex,onFocus:()=>{(onClick||isSelectable)&&(setSelectedIndex(i),setIsKeyboardFocus(!0))},onClick:()=>{setIsKeyboardFocus(!1),handleOnClick(item)},checkboxProps:isSelectable&&{name:"list-checkbox",size:"s",onChange:()=>handleOnClick(item),checked:selectedIdsSet.has(item.id)},renderLabel:()=>item.label,renderLeft:getLeftIconProps?({textSize})=>_react.default.createElement(_Icon.Icon,{...getLeftIconProps(item),size:textSize}):null,renderRight:({actionSize,textSize})=>renderRightContent?_react.default.createElement(StyledMinHeightCell,{textSize:textSize},renderRightContent({textSize,actionSize,...item})):null})}))}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityItemBody",{enumerable:!0,get:function(){return EntityItemBody}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Checkbox=require("../Form/Checkbox/Checkbox"),_EntityListItemText=require("./EntityListItemText"),_Inline=require("../Inline/Inline"),_styledcomponents=require("./styled-components"),StyledLabel=(0,_styled.default)(_styledcomponents.StyledWrapperOffset,{target:"
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityItemBody",{enumerable:!0,get:function(){return EntityItemBody}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_Checkbox=require("../Form/Checkbox/Checkbox"),_EntityListItemText=require("./EntityListItemText"),_Inline=require("../Inline/Inline"),_styledcomponents=require("./styled-components"),StyledLabel=(0,_styled.default)(_styledcomponents.StyledWrapperOffset,{target:"ernvwtf0",label:"StyledLabel"})(({theme,size})=>({cursor:"pointer",display:"block",margin:`-${theme.variables.size.spacing["xs"===size?"xxs":size]} 0`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRW50aXR5TGlzdC9FbnRpdHlJdGVtQm9keS50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0VudGl0eUxpc3QvRW50aXR5SXRlbUJvZHkudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCBSZWFjdCwgeyB1c2VDYWxsYmFjayB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IEZDLCBQcm9wc1dpdGhDaGlsZHJlbiB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHsgQ2hlY2tib3hSYXcgfSBmcm9tIFwiLi4vRm9ybS9DaGVja2JveC9DaGVja2JveFwiO1xuaW1wb3J0IHsgRW50aXR5TGlzdEl0ZW1UZXh0IH0gZnJvbSBcIi4vRW50aXR5TGlzdEl0ZW1UZXh0XCI7XG5pbXBvcnQgeyBJbmxpbmUgfSBmcm9tIFwiLi4vSW5saW5lL0lubGluZVwiO1xuaW1wb3J0IHsgU3R5bGVkV3JhcHBlck9mZnNldCB9IGZyb20gXCIuL3N0eWxlZC1jb21wb25lbnRzXCI7XG5pbXBvcnQgdHlwZSB7IEVudGl0eUxpc3RJdGVtUHJvcHMgfSBmcm9tIFwiLi90eXBlc1wiO1xuXG5jb25zdCBTdHlsZWRMYWJlbCA9IHN0eWxlZChTdHlsZWRXcmFwcGVyT2Zmc2V0KSgoeyB0aGVtZSwgc2l6ZSB9KSA9PiAoe1xuICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICBkaXNwbGF5OiBcImJsb2NrXCIsXG4gIG1hcmdpbjogYC0ke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmdbc2l6ZSA9PT0gXCJ4c1wiID8gXCJ4eHNcIiA6IHNpemVdfSAwYCxcbn0pKTtcblxuY29uc3QgU3RvcFByb3BhZ2F0aW9uV3JhcHBlcjogRkM8UHJvcHNXaXRoQ2hpbGRyZW4+ID0gKHsgY2hpbGRyZW4gfSkgPT4ge1xuICBjb25zdCBoYW5kbGVDbGljayA9IHVzZUNhbGxiYWNrKChlOiBSZWFjdC5Nb3VzZUV2ZW50KSA9PiB7XG4gICAgZS5zdG9wUHJvcGFnYXRpb24oKTtcbiAgfSwgW10pO1xuICByZXR1cm4gKFxuICAgIDxkaXYgcm9sZT1cInByZXNlbnRhdGlvblwiIG9uQ2xpY2s9e2hhbmRsZUNsaWNrfT5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5cbmV4cG9ydCBmdW5jdGlvbiBFbnRpdHlJdGVtQm9keSh7XG4gIGNoZWNrYm94UHJvcHMsXG4gIGRlc2NyaXB0aW9uLFxuICByZW5kZXJMYWJlbCxcbiAgcmVuZGVyTGVmdCxcbiAgcmVuZGVyUmlnaHQsXG4gIHRhYkluZGV4LFxuICBzaXplID0gXCJtXCIsXG59OiBQYXJ0aWFsPEVudGl0eUxpc3RJdGVtUHJvcHM+KTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgdGV4dFNpemUgPSBzaXplID09PSBcInhzXCIgPyBcInNcIiA6IFwibVwiO1xuICBjb25zdCBhY3Rpb25TaXplID0gc2l6ZSA9PT0gXCJsXCIgPyBcIm1cIiA6IFwic1wiO1xuXG4gIHJldHVybiAoXG4gICAgPElubGluZSBub1dyYXAgYWxpZ25JdGVtcz1cInNwYWNlQmV0d2VlblwiIHNwYWNlPXtbXCJ4c1wiLCBcIm1cIl19PlxuICAgICAge2NoZWNrYm94UHJvcHMgPyAoXG4gICAgICAgIDxTdHlsZWRMYWJlbCBhcz1cImxhYmVsXCIgc2l6ZT17c2l6ZX0+XG4gICAgICAgICAgPElubGluZSBub1dyYXAgc3BhY2U9e1tcInhzXCIsIFwibVwiXX0+XG4gICAgICAgICAgICA8Q2hlY2tib3hSYXcgey4uLmNoZWNrYm94UHJvcHN9IHRhYkluZGV4PXt0YWJJbmRleH0gLz5cbiAgICAgICAgICAgIDxFbnRpdHlMaXN0SXRlbVRleHQgc2l6ZT17dGV4dFNpemV9IGRlc2NyaXB0aW9uPXtkZXNjcmlwdGlvbn0+XG4gICAgICAgICAgICAgIHtyZW5kZXJMYWJlbCh7IHRleHRTaXplIH0pfVxuICAgICAgICAgICAgPC9FbnRpdHlMaXN0SXRlbVRleHQ+XG4gICAgICAgICAgPC9JbmxpbmU+XG4gICAgICAgIDwvU3R5bGVkTGFiZWw+XG4gICAgICApIDogKFxuICAgICAgICA8SW5saW5lIG5vV3JhcCBzcGFjZT17W1wieHNcIiwgXCJtXCJdfT5cbiAgICAgICAgICB7cmVuZGVyTGVmdCAmJiByZW5kZXJMZWZ0KHsgdGV4dFNpemUgfSl9XG4gICAgICAgICAgPEVudGl0eUxpc3RJdGVtVGV4dCBzaXplPXt0ZXh0U2l6ZX0gZGVzY3JpcHRpb249e2Rlc2NyaXB0aW9ufT5cbiAgICAgICAgICAgIHtyZW5kZXJMYWJlbCh7IHRleHRTaXplIH0pfVxuICAgICAgICAgIDwvRW50aXR5TGlzdEl0ZW1UZXh0PlxuICAgICAgICA8L0lubGluZT5cbiAgICAgICl9XG4gICAgICB7cmVuZGVyUmlnaHQgJiYgKFxuICAgICAgICA8U3RvcFByb3BhZ2F0aW9uV3JhcHBlcj5cbiAgICAgICAgICB7cmVuZGVyUmlnaHQoeyB0ZXh0U2l6ZSwgYWN0aW9uU2l6ZSB9KX1cbiAgICAgICAgPC9TdG9wUHJvcGFnYXRpb25XcmFwcGVyPlxuICAgICAgKX1cbiAgICA8L0lubGluZT5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVb0IifQ== */"),StopPropagationWrapper=({children})=>{let handleClick=(0,_react.useCallback)(e=>{e.stopPropagation()},[]);return _react.default.createElement("div",{role:"presentation",onClick:handleClick},children)};function EntityItemBody({checkboxProps,description,renderLabel,renderLeft,renderRight,tabIndex,size="m"}){let textSize="xs"===size?"s":"m";return _react.default.createElement(_Inline.Inline,{noWrap:!0,alignItems:"spaceBetween",space:["xs","m"]},checkboxProps?_react.default.createElement(StyledLabel,{as:"label",size:size},_react.default.createElement(_Inline.Inline,{noWrap:!0,space:["xs","m"]},_react.default.createElement(_Checkbox.CheckboxRaw,{...checkboxProps,tabIndex:tabIndex}),_react.default.createElement(_EntityListItemText.EntityListItemText,{size:textSize,description:description},renderLabel({textSize})))):_react.default.createElement(_Inline.Inline,{noWrap:!0,space:["xs","m"]},renderLeft&&renderLeft({textSize}),_react.default.createElement(_EntityListItemText.EntityListItemText,{size:textSize,description:description},renderLabel({textSize}))),renderRight&&_react.default.createElement(StopPropagationWrapper,null,renderRight({textSize,actionSize:"l"===size?"m":"s"})))}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityListItem",{enumerable:!0,get:function(){return EntityListItem}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_EntityItemBody=require("./EntityItemBody"),_useKeyboard=require("../../shared/useKeyboard"),_styledcomponents=require("./styled-components"),useButtonKeyboard=({ref:globalRef,isActive,onKeyDown})=>{let localRef=(0,_react.useRef)(null);return(0,_useKeyboard.useKeyboard)({"Space Enter":onKeyDown},localRef,isActive,!0),(0,_react.useImperativeHandle)(globalRef,()=>localRef.current),localRef},EntityListItem=_react.default.forwardRef(({checkboxProps,description,hideBorder,isActive,isClickable,isDisabled,onClick,renderLabel,renderLeft,renderRight,tabIndex,onKeyDown,size="m","aria-label":ariaLabel},ref)=>{let handleOnClick=(0,_react.useCallback)(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:isActive&&isClickable,onKeyDown});return _react.default.createElement(_styledcomponents.StyledEntityItemLi,{"aria-label":ariaLabel},_react.default.createElement(_styledcomponents.StyledEntityListItemButton,{size:size,tabIndex:tabIndex,ref:buttonRef,role:"presentation",onClick:handleOnClick,isClickable:isClickable,isActive:isActive,isDisabled:isDisabled},_react.default.createElement(_styledcomponents.StyledEntityListItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},_react.default.createElement(_EntityItemBody.EntityItemBody,{size:size,tabIndex:tabIndex,checkboxProps:checkboxProps,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight}))))});
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityListItem",{enumerable:!0,get:function(){return EntityListItem}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_EntityItemBody=require("./EntityItemBody"),_useKeyboard=require("../../shared/useKeyboard"),_styledcomponents=require("./styled-components"),useButtonKeyboard=({ref:globalRef,isActive,onKeyDown})=>{let localRef=(0,_react.useRef)(null);return(0,_useKeyboard.useKeyboard)({"Space Enter":onKeyDown},localRef,isActive,!0),(0,_react.useImperativeHandle)(globalRef,()=>localRef.current),localRef},EntityListItem=_react.default.forwardRef(({checkboxProps,description,hideBorder,isActive,isClickable,isDisabled,onClick,renderLabel,renderLeft,renderRight,tabIndex,onKeyDown,size="m","aria-label":ariaLabel},ref)=>{let handleOnClick=(0,_react.useCallback)(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:isActive&&isClickable,onKeyDown});return _react.default.createElement(_styledcomponents.StyledEntityItemLi,{"aria-label":ariaLabel},_react.default.createElement(_styledcomponents.StyledEntityListItemButton,{size:size,tabIndex:tabIndex,ref:buttonRef,role:"presentation","data-id":"list-item",onClick:handleOnClick,isClickable:isClickable,isActive:isActive,isDisabled:isDisabled},_react.default.createElement(_styledcomponents.StyledEntityListItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},_react.default.createElement(_EntityItemBody.EntityItemBody,{size:size,tabIndex:tabIndex,checkboxProps:checkboxProps,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight}))))});
|