@amboss/design-system 1.13.4 → 1.13.6

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.
Files changed (34) hide show
  1. package/build/cjs/build-tokens/_zindex.json.js +10 -0
  2. package/build/cjs/build-tokens/visualConfig.js +150 -4
  3. package/build/cjs/scss/themes/dark.scss +5 -4
  4. package/build/cjs/scss/themes/light.scss +3 -2
  5. package/build/cjs/src/components/Button/Button.js +18 -32
  6. package/build/cjs/src/components/Link/Link.js +5 -4
  7. package/build/cjs/src/components/Tooltip/Tooltip.js +275 -0
  8. package/build/cjs/src/components/Tooltip/utils.js +81 -0
  9. package/build/cjs/src/index.js +2 -0
  10. package/build/esm/build-tokens/_subThemeType.d.ts +1 -1
  11. package/build/esm/build-tokens/_zindex.json.js +4 -0
  12. package/build/esm/build-tokens/_zindex.json.js.map +1 -0
  13. package/build/esm/build-tokens/visualConfig.d.ts +74 -0
  14. package/build/esm/build-tokens/visualConfig.js +150 -4
  15. package/build/esm/build-tokens/visualConfig.js.map +1 -1
  16. package/build/esm/scss/themes/dark.scss +5 -4
  17. package/build/esm/scss/themes/light.scss +3 -2
  18. package/build/esm/src/components/Button/Button.d.ts +0 -1
  19. package/build/esm/src/components/Button/Button.js +18 -32
  20. package/build/esm/src/components/Button/Button.js.map +1 -1
  21. package/build/esm/src/components/Link/Link.d.ts +4 -5
  22. package/build/esm/src/components/Link/Link.js +5 -4
  23. package/build/esm/src/components/Link/Link.js.map +1 -1
  24. package/build/esm/src/components/Tooltip/Tooltip.d.ts +23 -0
  25. package/build/esm/src/components/Tooltip/Tooltip.js +269 -0
  26. package/build/esm/src/components/Tooltip/Tooltip.js.map +1 -0
  27. package/build/esm/src/components/Tooltip/utils.d.ts +11 -0
  28. package/build/esm/src/components/Tooltip/utils.js +75 -0
  29. package/build/esm/src/components/Tooltip/utils.js.map +1 -0
  30. package/build/esm/src/index.d.ts +1 -0
  31. package/build/esm/src/index.js +1 -0
  32. package/build/esm/src/index.js.map +1 -1
  33. package/package.json +2 -1
  34. package/build/esm/src/components/Button/mock.d.ts +0 -326
@@ -0,0 +1,10 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var dropdown={category:"zIndex",value:1,variableName:"$z-index-dropdown"};var tooltip={category:"zIndex",value:2,variableName:"$z-index-tooltip"};var modal={category:"zIndex",value:3,variableName:"$z-index-modal"};var zIndices = {dropdown:dropdown,tooltip:tooltip,modal:modal};
6
+
7
+ exports.default = zIndices;
8
+ exports.dropdown = dropdown;
9
+ exports.modal = modal;
10
+ exports.tooltip = tooltip;
@@ -370,6 +370,7 @@ const variables = {
370
370
  };
371
371
  const ambossVisualConfiguration = {
372
372
  "dark": {
373
+ "name": "dark",
373
374
  "variables": variables,
374
375
  "values": {
375
376
  "color": {
@@ -456,8 +457,8 @@ const ambossVisualConfiguration = {
456
457
  "default": "#757a84"
457
458
  },
458
459
  "accent": {
459
- "default": "#a6f2dd",
460
- "hover": "#e2fef7"
460
+ "default": "#41a48a",
461
+ "hover": "#a6f2dd"
461
462
  },
462
463
  "onAccent": {
463
464
  "default": "#ffffff",
@@ -510,7 +511,8 @@ const ambossVisualConfiguration = {
510
511
  }
511
512
  },
512
513
  "divider": {
513
- "primary": "rgba(147, 149, 159, 0.3)"
514
+ "primary": "#40454f",
515
+ "secondary": "rgba(147, 151, 159, 0.08)"
514
516
  },
515
517
  "toggle": {
516
518
  "background": {
@@ -766,6 +768,77 @@ const ambossVisualConfiguration = {
766
768
  }
767
769
  }
768
770
  },
771
+ "inverted": {
772
+ "color": {
773
+ "background": {
774
+ "primary": {
775
+ "default": "#d8dade"
776
+ },
777
+ "secondary": {
778
+ "default": "transparent",
779
+ "hover": "rgba(147, 151, 159, 0.08)"
780
+ },
781
+ "accent": {
782
+ "default": "#28816b",
783
+ "hover": "#233d3d",
784
+ "active": "#262e33",
785
+ "disabled": "rgba(40, 129, 107, 0.3)"
786
+ },
787
+ "transparent": {
788
+ "hover": "rgba(255, 255, 255, 0.08)"
789
+ }
790
+ },
791
+ "text": {
792
+ "primary": {
793
+ "default": "#1e2125",
794
+ "hover": "#1e2125"
795
+ },
796
+ "secondary": {
797
+ "default": "#40454f",
798
+ "hover": "#393e47"
799
+ },
800
+ "tertiary": {
801
+ "default": "#5b5f67",
802
+ "hover": "#40454f"
803
+ },
804
+ "accent": {
805
+ "default": "#28816b",
806
+ "hover": "#233d3d"
807
+ },
808
+ "onAccent": {
809
+ "default": "#ffffff"
810
+ },
811
+ "error": {
812
+ "default": "#4d3237"
813
+ },
814
+ "info": {
815
+ "default": "#29364c"
816
+ }
817
+ },
818
+ "icon": {
819
+ "primary": "#ffffff",
820
+ "secondary": "#40454f",
821
+ "tertiary": "#5b5f67",
822
+ "accent": "#28816b",
823
+ "onAccent": "#ffffff",
824
+ "info": "#29364c",
825
+ "error": "#4d3237"
826
+ },
827
+ "border": {
828
+ "primary": {
829
+ "default": "#757a84",
830
+ "hover": "#757a84",
831
+ "active": "#757a84"
832
+ },
833
+ "accent": {
834
+ "default": "#28816b"
835
+ }
836
+ },
837
+ "divider": {
838
+ "primary": "#b9bcc3"
839
+ }
840
+ }
841
+ },
769
842
  "success": {
770
843
  "color": {
771
844
  "background": {
@@ -837,6 +910,7 @@ const ambossVisualConfiguration = {
837
910
  }
838
911
  },
839
912
  "light": {
913
+ "name": "light",
840
914
  "variables": variables,
841
915
  "values": {
842
916
  "color": {
@@ -977,7 +1051,8 @@ const ambossVisualConfiguration = {
977
1051
  }
978
1052
  },
979
1053
  "divider": {
980
- "primary": "rgba(163, 178, 189, 0.3)"
1054
+ "primary": "#e0e6eb",
1055
+ "secondary": "rgba(163, 178, 189, 0.3)"
981
1056
  },
982
1057
  "toggle": {
983
1058
  "background": {
@@ -1233,6 +1308,77 @@ const ambossVisualConfiguration = {
1233
1308
  }
1234
1309
  }
1235
1310
  },
1311
+ "inverted": {
1312
+ "color": {
1313
+ "background": {
1314
+ "primary": {
1315
+ "default": "#1a1c1c"
1316
+ },
1317
+ "secondary": {
1318
+ "default": "transparent",
1319
+ "hover": "rgba(255, 255, 255, 0.08)"
1320
+ },
1321
+ "accent": {
1322
+ "default": "#ffffff",
1323
+ "hover": "rgba(255, 255, 255, 0.8)",
1324
+ "active": "rgba(255, 255, 255, 0.6)",
1325
+ "disabled": "rgba(255, 255, 255, 0.6)"
1326
+ },
1327
+ "transparent": {
1328
+ "hover": "rgba(255, 255, 255, 0.08)"
1329
+ }
1330
+ },
1331
+ "text": {
1332
+ "primary": {
1333
+ "default": "#ffffff",
1334
+ "hover": "rgba(255, 255, 255, 0.8)"
1335
+ },
1336
+ "secondary": {
1337
+ "default": "#e0e6eb",
1338
+ "hover": "#a3b2bd"
1339
+ },
1340
+ "tertiary": {
1341
+ "default": "#a3b2bd",
1342
+ "hover": "#607585"
1343
+ },
1344
+ "accent": {
1345
+ "default": "#8adcc6",
1346
+ "hover": "#0fa980"
1347
+ },
1348
+ "onAccent": {
1349
+ "default": "#314554"
1350
+ },
1351
+ "error": {
1352
+ "default": "#f07575"
1353
+ },
1354
+ "info": {
1355
+ "default": "#6e95cf"
1356
+ }
1357
+ },
1358
+ "icon": {
1359
+ "primary": "#ffffff",
1360
+ "secondary": "#e0e6eb",
1361
+ "tertiary": "#a3b2bd",
1362
+ "accent": "#8adcc6",
1363
+ "onAccent": "#314554",
1364
+ "info": "#6e95cf",
1365
+ "error": "#f07575"
1366
+ },
1367
+ "border": {
1368
+ "primary": {
1369
+ "default": "#ffffff",
1370
+ "hover": "#ffffff",
1371
+ "active": "#ffffff"
1372
+ },
1373
+ "accent": {
1374
+ "default": "#ffffff"
1375
+ }
1376
+ },
1377
+ "divider": {
1378
+ "primary": "#e0e6eb"
1379
+ }
1380
+ }
1381
+ },
1236
1382
  "success": {
1237
1383
  "color": {
1238
1384
  "background": {
@@ -1,6 +1,6 @@
1
1
 
2
2
  // Do not edit directly
3
- // Generated on Fri, 04 Aug 2023 08:05:19 GMT
3
+ // Generated on Mon, 07 Aug 2023 09:54:00 GMT
4
4
 
5
5
  $color-canvas: #1e2125;
6
6
  $color-background-primary-default: #24282d;
@@ -39,8 +39,8 @@ $color-text-tertiary-default: #93979f;
39
39
  $color-text-tertiary-disabled: rgba(216, 218, 222, 0.3);
40
40
  $color-text-tertiary-hover: #b9bcc3;
41
41
  $color-text-quaternary-default: #757a84;
42
- $color-text-accent-default: #a6f2dd;
43
- $color-text-accent-hover: #e2fef7;
42
+ $color-text-accent-default: #41a48a;
43
+ $color-text-accent-hover: #a6f2dd;
44
44
  $color-text-onAccent-default: #ffffff;
45
45
  $color-text-onAccent-disabled: rgba(216, 218, 222, 0.3);
46
46
  $color-text-info-default: #99c1fa;
@@ -66,7 +66,8 @@ $color-border-secondary-default: rgba(147, 149, 159, 0.3);
66
66
  $color-border-accent-default: #41a48a;
67
67
  $color-border-error-default: #d07c7c;
68
68
  $color-border-accentSubtle-default: #28816b;
69
- $color-divider-primary: rgba(147, 149, 159, 0.3);
69
+ $color-divider-primary: #40454f;
70
+ $color-divider-secondary: rgba(147, 151, 159, 0.08);
70
71
  $color-toggle-background-hightlight: #b2ab39;
71
72
  $color-toggle-border-hightlight: #b2ab39;
72
73
  $color-badge-background-default: transparent;
@@ -1,6 +1,6 @@
1
1
 
2
2
  // Do not edit directly
3
- // Generated on Fri, 04 Aug 2023 08:05:19 GMT
3
+ // Generated on Mon, 07 Aug 2023 09:54:00 GMT
4
4
 
5
5
  $color-canvas: #eef2f5;
6
6
  $color-background-primary-default: #ffffff;
@@ -66,7 +66,8 @@ $color-border-secondary-default: rgba(163, 178, 189, 0.3);
66
66
  $color-border-accent-default: #0b8363;
67
67
  $color-border-error-default: #dc4847;
68
68
  $color-border-accentSubtle-default: #8adcc6;
69
- $color-divider-primary: rgba(163, 178, 189, 0.3);
69
+ $color-divider-primary: #e0e6eb;
70
+ $color-divider-secondary: rgba(163, 178, 189, 0.3);
70
71
  $color-toggle-background-hightlight: #f3eb75;
71
72
  $color-toggle-border-hightlight: #f3eb75;
72
73
  $color-badge-background-default: #ffffff;
@@ -15,26 +15,6 @@ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
15
15
  var React__default = /*#__PURE__*/_interopDefault(React);
16
16
  var isPropValid__default = /*#__PURE__*/_interopDefault(isPropValid);
17
17
 
18
- const handleActive = (theme, variant) => {
19
- switch (variant) {
20
- case "primary":
21
- return {
22
- backgroundColor: theme.values.color.background.accent.active
23
- };
24
- case "secondary":
25
- return {
26
- backgroundColor: theme.values.color.background.transparent.default,
27
- borderColor: theme.values.color.border.primary.active
28
- };
29
- case "tertiary":
30
- return {
31
- color: theme.values.color.text.primary.default,
32
- backgroundColor: theme.values.color.background.transparent.active
33
- };
34
- default:
35
- throw new Error("There is no variant for this Button state");
36
- }
37
- };
38
18
  const StyledButton = /*#__PURE__*/_styled__default.default("button", process.env.NODE_ENV === "production" ? {
39
19
  shouldForwardProp: prop => isPropValid__default.default(prop),
40
20
  target: "e1vkw3t43"
@@ -48,8 +28,7 @@ const StyledButton = /*#__PURE__*/_styled__default.default("button", process.env
48
28
  fullWidth,
49
29
  size,
50
30
  squareCorners,
51
- variant,
52
- pseudoActiveClass
31
+ variant
53
32
  } = _ref;
54
33
  return {
55
34
  "&[type='button']": {
@@ -86,6 +65,9 @@ const StyledButton = /*#__PURE__*/_styled__default.default("button", process.env
86
65
  ":hover": {
87
66
  backgroundColor: theme.values.color.background.accent.hover
88
67
  },
68
+ ":active": {
69
+ backgroundColor: theme.values.color.background.accent.active
70
+ },
89
71
  ":disabled": {
90
72
  color: theme.values.color.text.onAccent.disabled,
91
73
  backgroundColor: theme.values.color.background.accent.disabled
@@ -100,6 +82,10 @@ const StyledButton = /*#__PURE__*/_styled__default.default("button", process.env
100
82
  borderColor: theme.values.color.border.primary.hover,
101
83
  backgroundColor: theme.values.color.background.transparent.hover
102
84
  },
85
+ ":active": {
86
+ backgroundColor: theme.values.color.background.transparent.default,
87
+ borderColor: theme.values.color.border.primary.active
88
+ },
103
89
  ":disabled": {
104
90
  borderColor: theme.values.color.border.primary.disabled
105
91
  },
@@ -124,6 +110,10 @@ const StyledButton = /*#__PURE__*/_styled__default.default("button", process.env
124
110
  color: theme.values.color.text.secondary.default,
125
111
  backgroundColor: theme.values.color.background.transparent.hover
126
112
  },
113
+ ":active": {
114
+ color: theme.values.color.text.primary.default,
115
+ backgroundColor: theme.values.color.background.transparent.active
116
+ },
127
117
  ":disabled": {
128
118
  backgroundColor: theme.values.color.background.transparent.default,
129
119
  borderColor: theme.values.color.border.secondary.default
@@ -149,13 +139,11 @@ const StyledButton = /*#__PURE__*/_styled__default.default("button", process.env
149
139
  [`border${actual}Radius`]: 0
150
140
  }), {})
151
141
  }),
152
- ...(pseudoActiveClass && handleActive(theme, variant)),
153
- ":active": handleActive(theme, variant),
154
142
  "&[disabled], &:disabled": {
155
143
  pointerEvents: "none"
156
144
  }
157
145
  };
158
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AAsCqB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Theme, keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst handleActive = (theme: Theme, variant: BaseVariations) => {\n  switch (variant) {\n    case \"primary\":\n      return {\n        backgroundColor: theme.values.color.background.accent.active,\n      };\n    case \"secondary\":\n      return {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.primary.active,\n      };\n    case \"tertiary\":\n      return {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      };\n    default:\n      throw new Error(\"There is no variant for this Button state\");\n  }\n};\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant, pseudoActiveClass }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":hover\": {\n        borderColor: theme.values.color.border.primary.hover,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    ...(pseudoActiveClass && handleActive(theme, variant)),\n    \":active\": handleActive(theme, variant),\n    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  pseudoActiveClass?: boolean;\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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, pseudoActiveClass } =\n      privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        pseudoActiveClass={pseudoActiveClass}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
146
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AAiBqB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":active\": {\n        backgroundColor: theme.values.color.background.accent.active,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":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.default,\n        borderColor: theme.values.color.border.primary.active,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":active\": {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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 } = privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\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                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
159
147
 
160
148
  // opted in for this hacky solution because emotion.js
161
149
  // doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193
@@ -171,7 +159,7 @@ const StyledInner = /*#__PURE__*/_styled__default.default("div", process.env.NOD
171
159
  return loading && {
172
160
  color: "transparent"
173
161
  };
174
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AAkKoB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Theme, keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst handleActive = (theme: Theme, variant: BaseVariations) => {\n  switch (variant) {\n    case \"primary\":\n      return {\n        backgroundColor: theme.values.color.background.accent.active,\n      };\n    case \"secondary\":\n      return {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.primary.active,\n      };\n    case \"tertiary\":\n      return {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      };\n    default:\n      throw new Error(\"There is no variant for this Button state\");\n  }\n};\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant, pseudoActiveClass }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":hover\": {\n        borderColor: theme.values.color.border.primary.hover,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    ...(pseudoActiveClass && handleActive(theme, variant)),\n    \":active\": handleActive(theme, variant),\n    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  pseudoActiveClass?: boolean;\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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, pseudoActiveClass } =\n      privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        pseudoActiveClass={pseudoActiveClass}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
162
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AAsJoB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":active\": {\n        backgroundColor: theme.values.color.background.accent.active,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":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.default,\n        borderColor: theme.values.color.border.primary.active,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":active\": {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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 } = privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\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                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
175
163
  const StyledLoaderWrap = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
176
164
  target: "e1vkw3t41"
177
165
  } : {
@@ -185,7 +173,7 @@ const StyledLoaderWrap = /*#__PURE__*/_styled__default.default("div", process.en
185
173
  left: "0",
186
174
  display: "flex",
187
175
  justifyContent: "center"
188
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AAyKyB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Theme, keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst handleActive = (theme: Theme, variant: BaseVariations) => {\n  switch (variant) {\n    case \"primary\":\n      return {\n        backgroundColor: theme.values.color.background.accent.active,\n      };\n    case \"secondary\":\n      return {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.primary.active,\n      };\n    case \"tertiary\":\n      return {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      };\n    default:\n      throw new Error(\"There is no variant for this Button state\");\n  }\n};\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant, pseudoActiveClass }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":hover\": {\n        borderColor: theme.values.color.border.primary.hover,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    ...(pseudoActiveClass && handleActive(theme, variant)),\n    \":active\": handleActive(theme, variant),\n    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  pseudoActiveClass?: boolean;\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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, pseudoActiveClass } =\n      privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        pseudoActiveClass={pseudoActiveClass}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
176
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AA6JyB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":active\": {\n        backgroundColor: theme.values.color.background.accent.active,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":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.default,\n        borderColor: theme.values.color.border.primary.active,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":active\": {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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 } = privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\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                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
189
177
  const rotation = react.keyframes({
190
178
  from: {
191
179
  transform: "rotate(0deg)"
@@ -202,7 +190,7 @@ const StyledLoader = /*#__PURE__*/_styled__default.default("div", process.env.NO
202
190
  })(() => ({
203
191
  position: "absolute",
204
192
  animation: `${rotation} 1s infinite linear`
205
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AA4LqB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Theme, keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst handleActive = (theme: Theme, variant: BaseVariations) => {\n  switch (variant) {\n    case \"primary\":\n      return {\n        backgroundColor: theme.values.color.background.accent.active,\n      };\n    case \"secondary\":\n      return {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.primary.active,\n      };\n    case \"tertiary\":\n      return {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      };\n    default:\n      throw new Error(\"There is no variant for this Button state\");\n  }\n};\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant, pseudoActiveClass }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":hover\": {\n        borderColor: theme.values.color.border.primary.hover,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    ...(pseudoActiveClass && handleActive(theme, variant)),\n    \":active\": handleActive(theme, variant),\n    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  pseudoActiveClass?: boolean;\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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, pseudoActiveClass } =\n      privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        pseudoActiveClass={pseudoActiveClass}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
193
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Button.tsx"],"names":[],"mappings":"AAgLqB","file":"Button.tsx","sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React, { AriaAttributes } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport { IconName, Icon } from \"../Icon/Icon\";\nimport {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop),\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({ theme, fullWidth, size, squareCorners, variant }) => ({\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.button.m,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.button.m,\n    lineHeight: theme.variables.size.lineHeight.button.m,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    \"&:disabled\": {\n      color: theme.values.color.text.tertiary.disabled,\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: theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      \":hover\": {\n        backgroundColor: theme.values.color.background.accent.hover,\n      },\n      \":active\": {\n        backgroundColor: theme.values.color.background.accent.active,\n      },\n      \":disabled\": {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: 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      \":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.default,\n        borderColor: theme.values.color.border.primary.active,\n      },\n      \":disabled\": {\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: theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.header.xxs,\n      lineHeight: theme.variables.size.lineHeight.header.xxs,\n      letterSpacing: 0.5,\n      textTransform: \"uppercase\",\n      \":hover\": {\n        color: theme.values.color.text.secondary.default,\n        backgroundColor: theme.values.color.background.transparent.hover,\n      },\n      \":active\": {\n        color: theme.values.color.text.primary.default,\n        backgroundColor: theme.values.color.background.transparent.active,\n      },\n      \":disabled\": {\n        backgroundColor: theme.values.color.background.transparent.default,\n        borderColor: theme.values.color.border.secondary.default,\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    \"&[disabled], &:disabled\": {\n      pointerEvents: \"none\",\n    },\n  })\n);\n\n// opted in for this hacky solution because emotion.js\n// doesn't support transient props yet. https://github.com/emotion-js/emotion/issues/2193\nconst StyledInner = styled.div<{ loading: number }>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(() => ({\n  position: \"relative\",\n  width: \"100%\",\n  height: \"100%\",\n  top: 0,\n  left: \"0\",\n  display: \"flex\",\n  justifyContent: \"center\",\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  position: \"absolute\",\n  animation: `${rotation} 1s infinite linear`,\n}));\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  rightIconVariant?: TextVariations;\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  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.ReactElement | null;\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      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 } = privateProps;\n\n    function handleClick(e: React.MouseEvent) {\n      if (disabled) {\n        e.preventDefault();\n      }\n      if (onClick) {\n        onClick(e);\n      }\n    }\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        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\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                size=\"s\"\n                name=\"loader\"\n                variant={variant}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading ? 1 : 0}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space=\"xxs\"\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIcon && (\n              <Icon\n                size=\"s\"\n                name={rightIcon}\n                variant={rightIconVariant}\n                data-testid={rightIcon}\n                data-e2e-test-id={rightIcon}\n              />\n            )}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"]} */");
206
194
  const Button = /*#__PURE__*/React__default.default.forwardRef((_ref3, ref) => {
207
195
  let {
208
196
  "data-e2e-test-id": dataE2eTestId,
@@ -228,8 +216,7 @@ const Button = /*#__PURE__*/React__default.default.forwardRef((_ref3, ref) => {
228
216
  const {
229
217
  squareCorners,
230
218
  alignItems,
231
- rightIconVariant,
232
- pseudoActiveClass
219
+ rightIconVariant
233
220
  } = privateProps;
234
221
  function handleClick(e) {
235
222
  if (disabled) {
@@ -254,8 +241,7 @@ const Button = /*#__PURE__*/React__default.default.forwardRef((_ref3, ref) => {
254
241
  size: size,
255
242
  onClick: handleClick,
256
243
  onFocus: onFocus,
257
- onBlur: onBlur,
258
- pseudoActiveClass: pseudoActiveClass
244
+ onBlur: onBlur
259
245
  }, ariaAttributes, rest), loading && /*#__PURE__*/React__default.default.createElement(StyledLoaderWrap, null, /*#__PURE__*/React__default.default.createElement(StyledLoader, null, /*#__PURE__*/React__default.default.createElement(Icon.Icon, {
260
246
  size: "s",
261
247
  name: "loader",