@amboss/design-system 3.13.14 → 3.13.16

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 (43) hide show
  1. package/build/cjs/components/Box/Box.d.ts +4 -0
  2. package/build/cjs/components/Box/Box.js +1 -1
  3. package/build/cjs/components/Button/Button.js +1 -1
  4. package/build/cjs/components/InteractiveBox/InteractiveBox.d.ts +15 -0
  5. package/build/cjs/components/InteractiveBox/InteractiveBox.js +1 -0
  6. package/build/cjs/index.d.ts +1 -0
  7. package/build/cjs/index.js +1 -1
  8. package/build/cjs/shared/mixins/getBaseButtonStyles.d.ts +7 -0
  9. package/build/cjs/shared/mixins/getBaseButtonStyles.js +1 -0
  10. package/build/cjs/shared/mixins/getButtonAppearanceReset.d.ts +2 -0
  11. package/build/cjs/shared/mixins/getButtonAppearanceReset.js +1 -0
  12. package/build/cjs/shared/mixins/getDisabledStyles.d.ts +6 -0
  13. package/build/cjs/shared/mixins/getDisabledStyles.js +1 -0
  14. package/build/cjs/shared/mixins/getFocusStyles.d.ts +2 -0
  15. package/build/cjs/shared/mixins/getFocusStyles.js +1 -0
  16. package/build/cjs/shared/mixins/getVariantStyles.d.ts +9 -0
  17. package/build/cjs/shared/mixins/getVariantStyles.js +1 -0
  18. package/build/cjs/shared/mixins/index.d.ts +5 -0
  19. package/build/cjs/shared/mixins/index.js +1 -0
  20. package/build/cjs/web-tokens/assets/icons.json +3 -1
  21. package/build/cjs/web-tokens/assets/icons16.json +3 -1
  22. package/build/esm/components/Box/Box.d.ts +4 -0
  23. package/build/esm/components/Box/Box.js +1 -1
  24. package/build/esm/components/Button/Button.js +1 -1
  25. package/build/esm/components/InteractiveBox/InteractiveBox.d.ts +15 -0
  26. package/build/esm/components/InteractiveBox/InteractiveBox.js +1 -0
  27. package/build/esm/index.d.ts +1 -0
  28. package/build/esm/index.js +1 -1
  29. package/build/esm/shared/mixins/getBaseButtonStyles.d.ts +7 -0
  30. package/build/esm/shared/mixins/getBaseButtonStyles.js +1 -0
  31. package/build/esm/shared/mixins/getButtonAppearanceReset.d.ts +2 -0
  32. package/build/esm/shared/mixins/getButtonAppearanceReset.js +1 -0
  33. package/build/esm/shared/mixins/getDisabledStyles.d.ts +6 -0
  34. package/build/esm/shared/mixins/getDisabledStyles.js +1 -0
  35. package/build/esm/shared/mixins/getFocusStyles.d.ts +2 -0
  36. package/build/esm/shared/mixins/getFocusStyles.js +1 -0
  37. package/build/esm/shared/mixins/getVariantStyles.d.ts +9 -0
  38. package/build/esm/shared/mixins/getVariantStyles.js +1 -0
  39. package/build/esm/shared/mixins/index.d.ts +5 -0
  40. package/build/esm/shared/mixins/index.js +1 -0
  41. package/build/esm/web-tokens/assets/icons.json +3 -1
  42. package/build/esm/web-tokens/assets/icons16.json +3 -1
  43. package/package.json +1 -1
@@ -33,4 +33,8 @@ export type BoxProps = {
33
33
  "data-e2e-test-id"?: string;
34
34
  height?: Property.Height | MQ<Property.Height>;
35
35
  };
36
+ export declare const StyledBox: import("@emotion/styled").StyledComponent<{
37
+ theme?: import("@emotion/react").Theme;
38
+ as?: React.ElementType;
39
+ } & BoxProps, React.DetailedHTMLProps<React.HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
36
40
  export declare function Box({ children, space, vSpace, rSpace, lSpace, tSpace, bSpace, alignText, role, ariaAttributes, height, id, "data-e2e-test-id": dataE2eTestId, }: BoxProps): React.ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Box",{enumerable:!0,get:function(){return Box}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),StyledBox=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"height"!==prop,target:"epqo6f70",label:"StyledBox"})(({theme,space,alignText="left"})=>(0,_mediaQueries.useResponsiveStyles)({padding:[space,theme.variables.size.spacing],textAlign:[alignText,{left:"left",right:"right",center:"center"}]}),({theme,vSpace})=>(0,_mediaQueries.useResponsiveStyles)({paddingTop:[vSpace,theme.variables.size.spacing],paddingBottom:[vSpace,theme.variables.size.spacing]}),({theme,rSpace,lSpace,tSpace,bSpace})=>(0,_mediaQueries.useResponsiveStyles)({paddingLeft:[lSpace,theme.variables.size.spacing],paddingRight:[rSpace,theme.variables.size.spacing],paddingTop:[tSpace,theme.variables.size.spacing],paddingBottom:[bSpace,theme.variables.size.spacing]}),({height})=>(0,_mediaQueries.useResponsiveValue)({height}),()=>({boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQm94L0JveC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0JveC9Cb3gudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgQXJpYUF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBpc1Byb3BWYWxpZCBmcm9tIFwiQGVtb3Rpb24vaXMtcHJvcC12YWxpZFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCB7XG4gIHVzZVJlc3BvbnNpdmVTdHlsZXMsXG4gIHVzZVJlc3BvbnNpdmVWYWx1ZSxcbn0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB0eXBlIHsgU3BhY2VTaXplcywgVGV4dEFsaWdubWVudCwgTVEgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgQm94UHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0Tm9kZTtcbiAgLyoqIFJlcHJlc2VudHMgYm90aCB2ZXJ0aWNhbCBhbmQgaG9yaXpvbnRhbCBwYWRkaW5ncy4gV2hlbiB1c2VkIGFsb25lLCB2ZXJ0aWNhbCBhbmQgaG9yaXpvbnRhbCBwYWRkaW5ncyB3aWxsIGhhdmUgdGhlIHNhbWUgdmFsdWUuXG4gICAqIFVzZSBcInZTcGFjZVwiIHByb3AgdG8gb3ZlcnJpZGUgdmVydGljYWwgcGFkZGluZyB2YWx1ZSBpbiBjYXNlIHlvdSB3YW50IGl0IGRpZmZlcmVudC5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIHBhZGRpbmcsIG1lZGl1bSBzY3JlZW4gcGFkZGluZywgbGFyZ2Ugc2NyZWVuIHBhZGRpbmddIG9yIG9uZSBwYWRkaW5nIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqICovXG4gIHNwYWNlPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogUmVwcmVzZW50cyB2ZXJ0aWNhbCBwYWRkaW5nLiBVc2VkIHRvIG92ZXJyaWRlIHRoZSB2ZXJ0aWNhbCBwYWRkaW5nIGZyb20gXCJzcGFjZVwiIHByb3AuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2ZXJ0aWNhbCBwYWRkaW5nLCBtZWRpdW0gc2NyZWVuIHZlcnRpY2FsIHBhZGRpbmcsIGxhcmdlIHNjcmVlbiB2ZXJ0aWNhbCBwYWRkaW5nXSBvciBvbmUgcGFkZGluZyBmb3IgYWxsIHNjcmVlbiBzaXplcyAqL1xuICB2U3BhY2U/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG4gIC8qKiByaWdodCBwYWRkaW5nICogKi9cbiAgclNwYWNlPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogbGVmdCBwYWRkaW5nICogKi9cbiAgbFNwYWNlPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogdG9wIHBhZGRpbmcgKiAqL1xuICB0U3BhY2U/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG4gIC8qKiBib3R0b20gcGFkZGluZyAqICovXG4gIGJTcGFjZT86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcblxuICAvKiogVGV4dCBhbGlnbm1lbnQgcHJvcC5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduVGV4dCwgbWVkaXVtIHNjcmVlbiBhbGlnblRleHQsIGxhcmdlIHNjcmVlbiBhbGlnblRleHRdIG9yIG9uZSBhbGlnblRleHQgZm9yIGFsbCBzY3JlZW4gc2l6ZXMgKi9cbiAgYWxpZ25UZXh0PzogVGV4dEFsaWdubWVudCB8IE1RPFRleHRBbGlnbm1lbnQ+O1xuXG4gIC8qKiBBcmlhIHByb3BlcnR5IGZvciBhc3NpZ25pbmcgYW4gYWNjZXNzaWJsZSByb2xlIHRvIGFuIGVsZW1lbnRcbiAgICogZWcuIGRpYWxvZywgdGFiLCB0b29sdGlwIGV0Yy4gKi9cbiAgcm9sZT86IHN0cmluZztcbiAgLyoqIEFkZGl0aW9uYWwgYXJpYSBhdHRyaWJ1dGVzLiBbc2VlIGRvY3VtZW50YXRpb25dKGh0dHBzOi8vZ2l0aHViLmNvbS9EZWZpbml0ZWx5VHlwZWQvRGVmaW5pdGVseVR5cGVkL2Jsb2IvMDI1NDljMDgzZTlkNjJiNjA0MDkxZDc3MGM0NTY4ZDQ3MjgyY2RkMC90eXBlcy9yZWFjdC9pbmRleC5kLnRzI0wxNDYxKVxuICAgKi9cbiAgYXJpYUF0dHJpYnV0ZXM/OiBBcmlhQXR0cmlidXRlcztcblxuICBpZD86IHN0cmluZztcblxuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcblxuICBoZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQgfCBNUTxQcm9wZXJ0eS5IZWlnaHQ+O1xufTtcblxuY29uc3QgU3R5bGVkQm94ID0gc3R5bGVkKFwiZGl2XCIsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IChwcm9wKSA9PiBpc1Byb3BWYWxpZChwcm9wKSAmJiBwcm9wICE9PSBcImhlaWdodFwiLFxufSk8Qm94UHJvcHM+KFxuICAoeyB0aGVtZSwgc3BhY2UsIGFsaWduVGV4dCA9IFwibGVmdFwiIH0pID0+XG4gICAgdXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICBwYWRkaW5nOiBbc3BhY2UsIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmddLFxuICAgICAgdGV4dEFsaWduOiBbXG4gICAgICAgIGFsaWduVGV4dCxcbiAgICAgICAgeyBsZWZ0OiBcImxlZnRcIiwgcmlnaHQ6IFwicmlnaHRcIiwgY2VudGVyOiBcImNlbnRlclwiIH0sXG4gICAgICBdLFxuICAgIH0pLFxuICAoeyB0aGVtZSwgdlNwYWNlIH0pID0+XG4gICAgdXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICBwYWRkaW5nVG9wOiBbdlNwYWNlLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIHBhZGRpbmdCb3R0b206IFt2U3BhY2UsIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmddLFxuICAgIH0pLFxuICAoeyB0aGVtZSwgclNwYWNlLCBsU3BhY2UsIHRTcGFjZSwgYlNwYWNlIH0pID0+XG4gICAgdXNlUmVzcG9uc2l2ZVN0eWxlcyh7XG4gICAgICBwYWRkaW5nTGVmdDogW2xTcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICBwYWRkaW5nUmlnaHQ6IFtyU3BhY2UsIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmddLFxuICAgICAgcGFkZGluZ1RvcDogW3RTcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICBwYWRkaW5nQm90dG9tOiBbYlNwYWNlLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICB9KSxcbiAgKHsgaGVpZ2h0IH0pID0+XG4gICAgdXNlUmVzcG9uc2l2ZVZhbHVlKHtcbiAgICAgIGhlaWdodCxcbiAgICB9KSxcbiAgKCkgPT4gKHtcbiAgICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxuICB9KVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIEJveCh7XG4gIGNoaWxkcmVuLFxuICBzcGFjZSA9IFwieGxcIixcbiAgdlNwYWNlLFxuICByU3BhY2UsXG4gIGxTcGFjZSxcbiAgdFNwYWNlLFxuICBiU3BhY2UsXG4gIGFsaWduVGV4dCxcbiAgcm9sZSxcbiAgYXJpYUF0dHJpYnV0ZXMsXG4gIGhlaWdodCxcbiAgaWQsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxufTogQm94UHJvcHMpOiBSZWFjdC5SZWFjdEVsZW1lbnQge1xuICByZXR1cm4gKFxuICAgIDxTdHlsZWRCb3hcbiAgICAgIHNwYWNlPXtzcGFjZX1cbiAgICAgIHZTcGFjZT17dlNwYWNlfVxuICAgICAgclNwYWNlPXtyU3BhY2V9XG4gICAgICBsU3BhY2U9e2xTcGFjZX1cbiAgICAgIHRTcGFjZT17dFNwYWNlfVxuICAgICAgYlNwYWNlPXtiU3BhY2V9XG4gICAgICBhbGlnblRleHQ9e2FsaWduVGV4dH1cbiAgICAgIHJvbGU9e3JvbGV9XG4gICAgICBpZD17aWR9XG4gICAgICBkYXRhLWUyZS10ZXN0LWlkPXtkYXRhRTJlVGVzdElkfVxuICAgICAgZGF0YS1kcy1pZD1cIkJveFwiXG4gICAgICBoZWlnaHQ9e2hlaWdodH1cbiAgICAgIHsuLi5hcmlhQXR0cmlidXRlc31cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRCb3g+XG4gICk7XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURrQiJ9 */");function Box({children,space="xl",vSpace,rSpace,lSpace,tSpace,bSpace,alignText,role,ariaAttributes,height,id,"data-e2e-test-id":dataE2eTestId}){return _react.default.createElement(StyledBox,{space:space,vSpace:vSpace,rSpace:rSpace,lSpace:lSpace,tSpace:tSpace,bSpace:bSpace,alignText:alignText,role:role,id:id,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Box",height:height,...ariaAttributes},children)}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get Box(){return Box},get StyledBox(){return StyledBox}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/_interop_require_default._(require("react")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_mediaQueries=require("../../shared/mediaQueries"),StyledBox=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"height"!==prop,target:"ebcgi2u0",label:"StyledBox"})(({theme,space,alignText="left"})=>(0,_mediaQueries.useResponsiveStyles)({padding:[space,theme.variables.size.spacing],textAlign:[alignText,{left:"left",right:"right",center:"center"}]}),({theme,vSpace})=>(0,_mediaQueries.useResponsiveStyles)({paddingTop:[vSpace,theme.variables.size.spacing],paddingBottom:[vSpace,theme.variables.size.spacing]}),({theme,rSpace,lSpace,tSpace,bSpace})=>(0,_mediaQueries.useResponsiveStyles)({paddingLeft:[lSpace,theme.variables.size.spacing],paddingRight:[rSpace,theme.variables.size.spacing],paddingTop:[tSpace,theme.variables.size.spacing],paddingBottom:[bSpace,theme.variables.size.spacing]}),({height})=>(0,_mediaQueries.useResponsiveValue)({height}),()=>({boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvQm94L0JveC50c3giLCJzb3VyY2VzIjpbInNyYy9jb21wb25lbnRzL0JveC9Cb3gudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbmltcG9ydCB0eXBlIHsgQXJpYUF0dHJpYnV0ZXMgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBSZWFjdCBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCBpc1Byb3BWYWxpZCBmcm9tIFwiQGVtb3Rpb24vaXMtcHJvcC12YWxpZFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFByb3BlcnR5IH0gZnJvbSBcImNzc3R5cGVcIjtcbmltcG9ydCB7XG4gIHVzZVJlc3BvbnNpdmVTdHlsZXMsXG4gIHVzZVJlc3BvbnNpdmVWYWx1ZSxcbn0gZnJvbSBcIi4uLy4uL3NoYXJlZC9tZWRpYVF1ZXJpZXNcIjtcbmltcG9ydCB0eXBlIHsgU3BhY2VTaXplcywgVGV4dEFsaWdubWVudCwgTVEgfSBmcm9tIFwiLi4vLi4vdHlwZXNcIjtcblxuZXhwb3J0IHR5cGUgQm94UHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGVbXSB8IFJlYWN0LlJlYWN0Tm9kZTtcbiAgLyoqIFJlcHJlc2VudHMgYm90aCB2ZXJ0aWNhbCBhbmQgaG9yaXpvbnRhbCBwYWRkaW5ncy4gV2hlbiB1c2VkIGFsb25lLCB2ZXJ0aWNhbCBhbmQgaG9yaXpvbnRhbCBwYWRkaW5ncyB3aWxsIGhhdmUgdGhlIHNhbWUgdmFsdWUuXG4gICAqIFVzZSBcInZTcGFjZVwiIHByb3AgdG8gb3ZlcnJpZGUgdmVydGljYWwgcGFkZGluZyB2YWx1ZSBpbiBjYXNlIHlvdSB3YW50IGl0IGRpZmZlcmVudC5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIHBhZGRpbmcsIG1lZGl1bSBzY3JlZW4gcGFkZGluZywgbGFyZ2Ugc2NyZWVuIHBhZGRpbmddIG9yIG9uZSBwYWRkaW5nIGZvciBhbGwgc2NyZWVuIHNpemVzXG4gICAqICovXG4gIHNwYWNlPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogUmVwcmVzZW50cyB2ZXJ0aWNhbCBwYWRkaW5nLiBVc2VkIHRvIG92ZXJyaWRlIHRoZSB2ZXJ0aWNhbCBwYWRkaW5nIGZyb20gXCJzcGFjZVwiIHByb3AuXG4gICAqIHNwZWNpZnkgW3NtYWxsIHNjcmVlbiB2ZXJ0aWNhbCBwYWRkaW5nLCBtZWRpdW0gc2NyZWVuIHZlcnRpY2FsIHBhZGRpbmcsIGxhcmdlIHNjcmVlbiB2ZXJ0aWNhbCBwYWRkaW5nXSBvciBvbmUgcGFkZGluZyBmb3IgYWxsIHNjcmVlbiBzaXplcyAqL1xuICB2U3BhY2U/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG4gIC8qKiByaWdodCBwYWRkaW5nICogKi9cbiAgclNwYWNlPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogbGVmdCBwYWRkaW5nICogKi9cbiAgbFNwYWNlPzogU3BhY2VTaXplcyB8IE1RPFNwYWNlU2l6ZXM+O1xuICAvKiogdG9wIHBhZGRpbmcgKiAqL1xuICB0U3BhY2U/OiBTcGFjZVNpemVzIHwgTVE8U3BhY2VTaXplcz47XG4gIC8qKiBib3R0b20gcGFkZGluZyAqICovXG4gIGJTcGFjZT86IFNwYWNlU2l6ZXMgfCBNUTxTcGFjZVNpemVzPjtcblxuICAvKiogVGV4dCBhbGlnbm1lbnQgcHJvcC5cbiAgICogc3BlY2lmeSBbc21hbGwgc2NyZWVuIGFsaWduVGV4dCwgbWVkaXVtIHNjcmVlbiBhbGlnblRleHQsIGxhcmdlIHNjcmVlbiBhbGlnblRleHRdIG9yIG9uZSBhbGlnblRleHQgZm9yIGFsbCBzY3JlZW4gc2l6ZXMgKi9cbiAgYWxpZ25UZXh0PzogVGV4dEFsaWdubWVudCB8IE1RPFRleHRBbGlnbm1lbnQ+O1xuXG4gIC8qKiBBcmlhIHByb3BlcnR5IGZvciBhc3NpZ25pbmcgYW4gYWNjZXNzaWJsZSByb2xlIHRvIGFuIGVsZW1lbnRcbiAgICogZWcuIGRpYWxvZywgdGFiLCB0b29sdGlwIGV0Yy4gKi9cbiAgcm9sZT86IHN0cmluZztcbiAgLyoqIEFkZGl0aW9uYWwgYXJpYSBhdHRyaWJ1dGVzLiBbc2VlIGRvY3VtZW50YXRpb25dKGh0dHBzOi8vZ2l0aHViLmNvbS9EZWZpbml0ZWx5VHlwZWQvRGVmaW5pdGVseVR5cGVkL2Jsb2IvMDI1NDljMDgzZTlkNjJiNjA0MDkxZDc3MGM0NTY4ZDQ3MjgyY2RkMC90eXBlcy9yZWFjdC9pbmRleC5kLnRzI0wxNDYxKVxuICAgKi9cbiAgYXJpYUF0dHJpYnV0ZXM/OiBBcmlhQXR0cmlidXRlcztcblxuICBpZD86IHN0cmluZztcblxuICBcImRhdGEtZTJlLXRlc3QtaWRcIj86IHN0cmluZztcblxuICBoZWlnaHQ/OiBQcm9wZXJ0eS5IZWlnaHQgfCBNUTxQcm9wZXJ0eS5IZWlnaHQ+O1xufTtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZEJveCA9IHN0eWxlZChcImRpdlwiLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT4gaXNQcm9wVmFsaWQocHJvcCkgJiYgcHJvcCAhPT0gXCJoZWlnaHRcIixcbn0pPEJveFByb3BzPihcbiAgKHsgdGhlbWUsIHNwYWNlLCBhbGlnblRleHQgPSBcImxlZnRcIiB9KSA9PlxuICAgIHVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgcGFkZGluZzogW3NwYWNlLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIHRleHRBbGlnbjogW1xuICAgICAgICBhbGlnblRleHQsXG4gICAgICAgIHsgbGVmdDogXCJsZWZ0XCIsIHJpZ2h0OiBcInJpZ2h0XCIsIGNlbnRlcjogXCJjZW50ZXJcIiB9LFxuICAgICAgXSxcbiAgICB9KSxcbiAgKHsgdGhlbWUsIHZTcGFjZSB9KSA9PlxuICAgIHVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgcGFkZGluZ1RvcDogW3ZTcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgICBwYWRkaW5nQm90dG9tOiBbdlNwYWNlLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICB9KSxcbiAgKHsgdGhlbWUsIHJTcGFjZSwgbFNwYWNlLCB0U3BhY2UsIGJTcGFjZSB9KSA9PlxuICAgIHVzZVJlc3BvbnNpdmVTdHlsZXMoe1xuICAgICAgcGFkZGluZ0xlZnQ6IFtsU3BhY2UsIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmddLFxuICAgICAgcGFkZGluZ1JpZ2h0OiBbclNwYWNlLCB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nXSxcbiAgICAgIHBhZGRpbmdUb3A6IFt0U3BhY2UsIHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmddLFxuICAgICAgcGFkZGluZ0JvdHRvbTogW2JTcGFjZSwgdGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZ10sXG4gICAgfSksXG4gICh7IGhlaWdodCB9KSA9PlxuICAgIHVzZVJlc3BvbnNpdmVWYWx1ZSh7XG4gICAgICBoZWlnaHQsXG4gICAgfSksXG4gICgpID0+ICh7XG4gICAgYm94U2l6aW5nOiBcImJvcmRlci1ib3hcIixcbiAgfSlcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiBCb3goe1xuICBjaGlsZHJlbixcbiAgc3BhY2UgPSBcInhsXCIsXG4gIHZTcGFjZSxcbiAgclNwYWNlLFxuICBsU3BhY2UsXG4gIHRTcGFjZSxcbiAgYlNwYWNlLFxuICBhbGlnblRleHQsXG4gIHJvbGUsXG4gIGFyaWFBdHRyaWJ1dGVzLFxuICBoZWlnaHQsXG4gIGlkLFxuICBcImRhdGEtZTJlLXRlc3QtaWRcIjogZGF0YUUyZVRlc3RJZCxcbn06IEJveFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgcmV0dXJuIChcbiAgICA8U3R5bGVkQm94XG4gICAgICBzcGFjZT17c3BhY2V9XG4gICAgICB2U3BhY2U9e3ZTcGFjZX1cbiAgICAgIHJTcGFjZT17clNwYWNlfVxuICAgICAgbFNwYWNlPXtsU3BhY2V9XG4gICAgICB0U3BhY2U9e3RTcGFjZX1cbiAgICAgIGJTcGFjZT17YlNwYWNlfVxuICAgICAgYWxpZ25UZXh0PXthbGlnblRleHR9XG4gICAgICByb2xlPXtyb2xlfVxuICAgICAgaWQ9e2lkfVxuICAgICAgZGF0YS1lMmUtdGVzdC1pZD17ZGF0YUUyZVRlc3RJZH1cbiAgICAgIGRhdGEtZHMtaWQ9XCJCb3hcIlxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICB7Li4uYXJpYUF0dHJpYnV0ZXN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvU3R5bGVkQm94PlxuICApO1xufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlEeUIifQ== */");function Box({children,space="xl",vSpace,rSpace,lSpace,tSpace,bSpace,alignText,role,ariaAttributes,height,id,"data-e2e-test-id":dataE2eTestId}){return _react.default.createElement(StyledBox,{space:space,vSpace:vSpace,rSpace:rSpace,lSpace:lSpace,tSpace:tSpace,bSpace:bSpace,alignText:alignText,role:role,id:id,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Box",height:height,...ariaAttributes},children)}
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Button",{enumerable:!0,get:function(){return Button}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Inline=require("../Inline/Inline"),_Icon=require("../Icon/Icon"),StyledButton=(0,_styled.default)("button",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"e1reo4960",label:"StyledButton"})(({theme,fullWidth,destructive,size,squareCorners,variant,disabled,loading})=>({"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",border:0,margin:0,textTransform:"none",textDecoration:"none",borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,cursor:"pointer",...disabled&&{...!loading&&{opacity:theme.variables.opacity.disabled},cursor:"not-allowed"},..."s"===size&&{padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`},..."m"===size&&{padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},..."l"===size&&{padding:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`},..."primary"===variant&&{backgroundColor:destructive?theme.values.color.background.error.default:theme.values.color.background.accent.default,color:theme.values.color.text.onAccent.default,...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.background.error.hover:theme.values.color.background.accent.hover},"&:active":{backgroundColor:destructive?theme.values.color.background.error.active:theme.values.color.background.accent.active}},...loading&&{color:theme.values.color.text.onAccent.disabled,backgroundColor:destructive?theme.values.color.background.error.disabled:theme.values.color.background.accent.disabled}},..."secondary"===variant&&{border:"1px solid",backgroundColor:theme.values.color.background.transparent.default,borderColor:theme.values.color.border.primary.default,color:theme.values.color.text.secondary.default,...!disabled&&{"&:hover":{borderColor:theme.values.color.border.primary.hover,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active}},...loading&&{borderColor:theme.values.color.border.primary.disabled},..."s"===size&&{padding:`${parseInt(theme.variables.size.spacing.xs,10)-1}px ${parseInt(theme.variables.size.spacing.m,10)-1}px`},..."m"===size&&{padding:`${parseInt(theme.variables.size.spacing.s,10)-1}px ${parseInt(theme.variables.size.spacing.l,10)-1}px`},..."l"===size&&{padding:`${parseInt(theme.variables.size.spacing.m,10)-1}px ${parseInt(theme.variables.size.spacing.xl,10)-1}px`}},..."tertiary"===variant&&{color:destructive?theme.values.color.text.error.default:theme.values.color.text.secondary.default,backgroundColor:theme.values.color.background.transparent.default,fontSize:theme.variables.size.font.xs,lineHeight:theme.variables.size.lineHeight.m,letterSpacing:theme.variables.size.letterSpacing.s,textTransform:"uppercase",...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.hover:theme.values.color.background.transparent.hover},"&:active":{color:destructive?theme.values.color.text.error.default:theme.values.color.text.primary.default,backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.active:theme.values.color.background.transparent.active}},..."s"===size&&{padding:theme.variables.size.spacing.xs},..."m"===size&&{padding:theme.variables.size.spacing.s},..."l"===size&&{padding:theme.variables.size.spacing.m}},...fullWidth&&{width:"100%"},...squareCorners&&"boolean"==typeof squareCorners?{borderRadius:0}:squareCorners&&"boolean"!=typeof squareCorners&&{...squareCorners.reduce((prev,actual)=>({...prev,[`border${actual}Radius`]:0}),{})}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAsBqB"} */"),StyledInner=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"e1reo4961",label:"StyledInner"})(({loading})=>loading&&{color:"transparent"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAkLoB"} */"),StyledLoaderWrap=(0,_styled.default)("div",{target:"e1reo4962",label:"StyledLoaderWrap"})(()=>({position:"relative",width:"100%",height:"100%",top:0,left:0,display:"flex",justifyContent:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA2LyB"} */"),rotation=(0,_react1.keyframes)({from:{transform:"rotate(0deg)"},to:{transform:"rotate(360deg)"}},"label:rotation","/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwMiB"} */"),StyledLoader=(0,_styled.default)("div",{target:"e1reo4963",label:"StyledLoader"})(()=>({position:"absolute",animation:`${rotation} 1s infinite linear`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    \"&[type='button']\": {\n      appearance: \"none\",\n      MozAppearance: \"none\",\n      WebkitAppearance: \"none\",\n    },\n    display: \"inline-block\",\n    border: 0,\n    margin: 0,\n    textTransform: \"none\",\n    textDecoration: \"none\",\n    borderRadius: theme.variables.size.borderRadius.xs,\n    fontFamily: theme.variables.fontFamily.lato,\n    fontSize: theme.variables.size.font.s,\n    lineHeight: theme.variables.size.lineHeight.xs,\n    fontWeight: theme.variables.weight.bold,\n    cursor: \"pointer\",\n    ...(disabled && {\n      ...(!loading && {\n        opacity: theme.variables.opacity.disabled,\n      }),\n      cursor: \"not-allowed\",\n    }),\n    ...(size === \"s\" && {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n    }),\n    ...(size === \"m\" && {\n      padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n    }),\n    ...(size === \"l\" && {\n      padding: `${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`,\n    }),\n    ...(variant === \"primary\" && {\n      backgroundColor: destructive\n        ? theme.values.color.background.error.default\n        : theme.values.color.background.accent.default,\n      color: theme.values.color.text.onAccent.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.hover\n            : theme.values.color.background.accent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: destructive\n            ? theme.values.color.background.error.active\n            : theme.values.color.background.accent.active,\n        },\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n    ...(variant === \"secondary\" && {\n      border: \"1px solid\",\n      backgroundColor: theme.values.color.background.transparent.default,\n      borderColor: theme.values.color.border.primary.default,\n      color: theme.values.color.text.secondary.default,\n      ...(!disabled && {\n        \"&:hover\": {\n          borderColor: theme.values.color.border.primary.hover,\n          backgroundColor: theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          backgroundColor: theme.values.color.background.transparent.active,\n          borderColor: theme.values.color.border.primary.active,\n        },\n      }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n      ...(size === \"s\" && {\n        padding: `${parseInt(theme.variables.size.spacing.xs, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.m, 10) - 1\n        }px`,\n      }),\n      ...(size === \"m\" && {\n        padding: `${parseInt(theme.variables.size.spacing.s, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.l, 10) - 1\n        }px`,\n      }),\n      ...(size === \"l\" && {\n        padding: `${parseInt(theme.variables.size.spacing.m, 10) - 1}px ${\n          parseInt(theme.variables.size.spacing.xl, 10) - 1\n        }px`,\n      }),\n    }),\n    ...(variant === \"tertiary\" && {\n      color: destructive\n        ? theme.values.color.text.error.default\n        : theme.values.color.text.secondary.default,\n      backgroundColor: theme.values.color.background.transparent.default,\n      fontSize: theme.variables.size.font.xs,\n      lineHeight: theme.variables.size.lineHeight.m,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      textTransform: \"uppercase\",\n      ...(!disabled && {\n        \"&:hover\": {\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.hover\n            : theme.values.color.background.transparent.hover,\n        },\n        \"&:active\": {\n          color: destructive\n            ? theme.values.color.text.error.default\n            : theme.values.color.text.primary.default,\n          backgroundColor: destructive\n            ? theme.values.color.destructiveTertiaryButton.background.active\n            : theme.values.color.background.transparent.active,\n        },\n      }),\n      ...(size === \"s\" && {\n        padding: theme.variables.size.spacing.xs,\n      }),\n      ...(size === \"m\" && {\n        padding: theme.variables.size.spacing.s,\n      }),\n      ...(size === \"l\" && {\n        padding: theme.variables.size.spacing.m,\n      }),\n    }),\n    ...(fullWidth && {\n      width: \"100%\",\n    }),\n    ...(squareCorners && typeof squareCorners === \"boolean\"\n      ? {\n          borderRadius: 0,\n        }\n      : squareCorners &&\n        typeof squareCorners !== \"boolean\" && {\n          ...squareCorners.reduce(\n            (prev, actual: string) => ({\n              ...prev,\n              [`border${actual}Radius`]: 0,\n            }),\n            {}\n          ),\n        }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiNqB"} */"),Button=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,ariaAttributes,as,children,disabled=!1,fullWidth=!1,destructive=!1,leftIcon,loading=!1,onBlur,onClick,onFocus,privateProps={squareCorners:!1},rightIcon,size="m",type="button",variant="primary",...rest},ref)=>{let{squareCorners,alignItems,rightIconVariant,rightIconColor}=privateProps,handleClick=(0,_react.useCallback)(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]),rightIconElm=rightIcon?_react.default.createElement(_Icon.Icon,{size:"s",name:rightIcon,...rightIconVariant&&!rightIconColor&&{variant:rightIconVariant},...rightIconColor&&{color:rightIconColor},"data-testid":rightIcon,"data-e2e-test-id":rightIcon,"aria-hidden":!0}):null;return _react.default.createElement(StyledButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Button",as:as,disabled:disabled||loading,loading:loading,type:as&&"button"!==as?void 0:type,fullWidth:fullWidth,destructive:destructive,squareCorners:squareCorners,variant:variant,size:size,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},loading&&_react.default.createElement(StyledLoaderWrap,null,_react.default.createElement(StyledLoader,null,_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:"loader",color:function(variant,destructive){switch(variant){case"primary":return destructive?"error":"accent";case"secondary":return"primary";default:return destructive?"error":variant}}(variant,destructive),"data-testid":"loader","data-e2e-test-id":"loader"}))),_react.default.createElement(StyledInner,{loading:loading},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:alignItems||"center",space:"s"===size?"xxs":"xs",noWrap:!0},leftIcon&&_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:leftIcon,"data-testid":leftIcon,"data-e2e-test-id":leftIcon}),children,rightIconElm)))});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"Button",{enumerable:!0,get:function(){return Button}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_react1=require("@emotion/react"),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Inline=require("../Inline/Inline"),_Icon=require("../Icon/Icon"),_mixins=require("../../shared/mixins"),StyledButton=(0,_styled.default)("button",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"e1oh887s0",label:"StyledButton"})(({theme,fullWidth,destructive,size,squareCorners,variant,disabled,loading})=>({...(0,_mixins.getButtonAppearanceReset)(),...(0,_mixins.getBaseButtonStyles)({theme,size}),..."primary"===variant&&{...(0,_mixins.getPrimaryVariantStyles)({theme,destructive,disabled}),...loading&&{color:theme.values.color.text.onAccent.disabled,backgroundColor:destructive?theme.values.color.background.error.disabled:theme.values.color.background.accent.disabled}},..."secondary"===variant&&{...(0,_mixins.getSecondaryVariantStyles)({theme,disabled,size,destructive}),...loading&&{borderColor:theme.values.color.border.primary.disabled}},..."tertiary"===variant&&{...(0,_mixins.getTertiaryVariantStyles)({theme,destructive,disabled,size}),fontSize:theme.variables.size.font.xs,letterSpacing:theme.variables.size.letterSpacing.s,lineHeight:theme.variables.size.lineHeight.m,textTransform:"uppercase"},...disabled&&{...!loading&&{...(0,_mixins.getDisabledStyles)({theme})},cursor:"not-allowed"},...squareCorners&&"boolean"==typeof squareCorners?{borderRadius:0}:squareCorners&&"boolean"!=typeof squareCorners&&{...squareCorners.reduce((prev,actual)=>({...prev,[`border${actual}Radius`]:0}),{})},...fullWidth&&{width:"100%"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nimport {\n  getDisabledStyles,\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getPrimaryVariantStyles,\n  getSecondaryVariantStyles,\n  getTertiaryVariantStyles,\n} from \"../../shared/mixins\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme, size }),\n\n    ...(variant === \"primary\" && {\n      ...getPrimaryVariantStyles({\n        theme,\n        destructive,\n        disabled,\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n\n    ...(variant === \"secondary\" && {\n      ...getSecondaryVariantStyles({ theme, disabled, size, destructive }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n    }),\n\n    ...(variant === \"tertiary\" && {\n      ...getTertiaryVariantStyles({ theme, destructive, disabled, size }),\n      fontSize: theme.variables.size.font.xs,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      lineHeight: theme.variables.size.lineHeight.m,\n      textTransform: \"uppercase\",\n    }),\n\n    ...(disabled && {\n      ...(!loading && {\n        ...getDisabledStyles({ theme }),\n      }),\n      cursor: \"not-allowed\",\n    }),\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    ...(fullWidth && {\n      width: \"100%\",\n    }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA+BqB"} */"),StyledInner=(0,_styled.default)("div",{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"loading"!==prop,target:"e1oh887s1",label:"StyledInner"})(({loading})=>loading&&{color:"transparent"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nimport {\n  getDisabledStyles,\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getPrimaryVariantStyles,\n  getSecondaryVariantStyles,\n  getTertiaryVariantStyles,\n} from \"../../shared/mixins\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme, size }),\n\n    ...(variant === \"primary\" && {\n      ...getPrimaryVariantStyles({\n        theme,\n        destructive,\n        disabled,\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n\n    ...(variant === \"secondary\" && {\n      ...getSecondaryVariantStyles({ theme, disabled, size, destructive }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n    }),\n\n    ...(variant === \"tertiary\" && {\n      ...getTertiaryVariantStyles({ theme, destructive, disabled, size }),\n      fontSize: theme.variables.size.font.xs,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      lineHeight: theme.variables.size.lineHeight.m,\n      textTransform: \"uppercase\",\n    }),\n\n    ...(disabled && {\n      ...(!loading && {\n        ...getDisabledStyles({ theme }),\n      }),\n      cursor: \"not-allowed\",\n    }),\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    ...(fullWidth && {\n      width: \"100%\",\n    }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAwGoB"} */"),StyledLoaderWrap=(0,_styled.default)("div",{target:"e1oh887s2",label:"StyledLoaderWrap"})(()=>({position:"relative",width:"100%",height:"100%",top:0,left:0,display:"flex",justifyContent:"center"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nimport {\n  getDisabledStyles,\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getPrimaryVariantStyles,\n  getSecondaryVariantStyles,\n  getTertiaryVariantStyles,\n} from \"../../shared/mixins\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme, size }),\n\n    ...(variant === \"primary\" && {\n      ...getPrimaryVariantStyles({\n        theme,\n        destructive,\n        disabled,\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n\n    ...(variant === \"secondary\" && {\n      ...getSecondaryVariantStyles({ theme, disabled, size, destructive }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n    }),\n\n    ...(variant === \"tertiary\" && {\n      ...getTertiaryVariantStyles({ theme, destructive, disabled, size }),\n      fontSize: theme.variables.size.font.xs,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      lineHeight: theme.variables.size.lineHeight.m,\n      textTransform: \"uppercase\",\n    }),\n\n    ...(disabled && {\n      ...(!loading && {\n        ...getDisabledStyles({ theme }),\n      }),\n      cursor: \"not-allowed\",\n    }),\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    ...(fullWidth && {\n      width: \"100%\",\n    }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAiHyB"} */"),rotation=(0,_react1.keyframes)({from:{transform:"rotate(0deg)"},to:{transform:"rotate(360deg)"}},"label:rotation","/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nimport {\n  getDisabledStyles,\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getPrimaryVariantStyles,\n  getSecondaryVariantStyles,\n  getTertiaryVariantStyles,\n} from \"../../shared/mixins\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme, size }),\n\n    ...(variant === \"primary\" && {\n      ...getPrimaryVariantStyles({\n        theme,\n        destructive,\n        disabled,\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n\n    ...(variant === \"secondary\" && {\n      ...getSecondaryVariantStyles({ theme, disabled, size, destructive }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n    }),\n\n    ...(variant === \"tertiary\" && {\n      ...getTertiaryVariantStyles({ theme, destructive, disabled, size }),\n      fontSize: theme.variables.size.font.xs,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      lineHeight: theme.variables.size.lineHeight.m,\n      textTransform: \"uppercase\",\n    }),\n\n    ...(disabled && {\n      ...(!loading && {\n        ...getDisabledStyles({ theme }),\n      }),\n      cursor: \"not-allowed\",\n    }),\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    ...(fullWidth && {\n      width: \"100%\",\n    }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AA8HiB"} */"),StyledLoader=(0,_styled.default)("div",{target:"e1oh887s3",label:"StyledLoader"})(()=>({position:"absolute",animation:`${rotation} 1s infinite linear`}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Button/Button.tsx","sources":["src/components/Button/Button.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport type { AriaAttributes } from \"react\";\nimport React, { useCallback } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { CSSObject } from \"@emotion/react\";\nimport { keyframes } from \"@emotion/react\";\nimport isPropValid from \"@emotion/is-prop-valid\";\n\nimport { Inline } from \"../Inline/Inline\";\nimport type { IconName } from \"../Icon/Icon\";\nimport { Icon } from \"../Icon/Icon\";\nimport type {\n  BaseVariations,\n  ButtonSize,\n  HorizontalAlignment,\n  TextVariations,\n  PolymorphicRef,\n  PolymorphicComponentPropsWithRef,\n  IconsColors,\n  MQ,\n} from \"../../types\";\n\nimport {\n  getDisabledStyles,\n  getButtonAppearanceReset,\n  getBaseButtonStyles,\n  getPrimaryVariantStyles,\n  getSecondaryVariantStyles,\n  getTertiaryVariantStyles,\n} from \"../../shared/mixins\";\n\nconst StyledButton = styled(\"button\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Partial<ButtonProps> & Partial<ButtonPrivateProps>>(\n  ({\n    theme,\n    fullWidth,\n    destructive,\n    size,\n    squareCorners,\n    variant,\n    disabled,\n    loading,\n  }) => ({\n    ...getButtonAppearanceReset(),\n    ...getBaseButtonStyles({ theme, size }),\n\n    ...(variant === \"primary\" && {\n      ...getPrimaryVariantStyles({\n        theme,\n        destructive,\n        disabled,\n      }),\n      ...(loading && {\n        color: theme.values.color.text.onAccent.disabled,\n        backgroundColor: destructive\n          ? theme.values.color.background.error.disabled\n          : theme.values.color.background.accent.disabled,\n      }),\n    }),\n\n    ...(variant === \"secondary\" && {\n      ...getSecondaryVariantStyles({ theme, disabled, size, destructive }),\n      ...(loading && {\n        borderColor: theme.values.color.border.primary.disabled,\n      }),\n    }),\n\n    ...(variant === \"tertiary\" && {\n      ...getTertiaryVariantStyles({ theme, destructive, disabled, size }),\n      fontSize: theme.variables.size.font.xs,\n      letterSpacing: theme.variables.size.letterSpacing.s,\n      lineHeight: theme.variables.size.lineHeight.m,\n      textTransform: \"uppercase\",\n    }),\n\n    ...(disabled && {\n      ...(!loading && {\n        ...getDisabledStyles({ theme }),\n      }),\n      cursor: \"not-allowed\",\n    }),\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    ...(fullWidth && {\n      width: \"100%\",\n    }),\n  })\n);\n\nconst StyledInner = styled(\"div\", {\n  shouldForwardProp: (prop) => isPropValid(prop) && prop !== \"loading\",\n})<Pick<ButtonProps, \"loading\">>(\n  ({ loading }) =>\n    loading && {\n      color: \"transparent\",\n    }\n);\n\nconst StyledLoaderWrap = styled.div(\n  () =>\n    ({\n      position: \"relative\",\n      width: \"100%\",\n      height: \"100%\",\n      top: 0,\n      left: 0,\n      display: \"flex\",\n      justifyContent: \"center\",\n    } as CSSObject)\n);\n\nconst rotation = keyframes({\n  from: {\n    transform: \"rotate(0deg)\",\n  },\n  to: {\n    transform: \"rotate(360deg)\",\n  },\n});\n\nconst StyledLoader = styled.div(\n  () =>\n    ({\n      position: \"absolute\",\n      animation: `${rotation} 1s infinite linear`,\n    } as CSSObject)\n);\n\ntype ButtonPrivateProps = {\n  squareCorners?:\n    | boolean\n    | (\"TopLeft\" | \"TopRight\" | \"BottomLeft\" | \"BottomRight\")[];\n  alignItems?: HorizontalAlignment;\n  /* @deprecated: Use rightIconColor prop instead */\n  rightIconVariant?: TextVariations;\n  rightIconColor?: IconsColors;\n};\n\nexport type ButtonProps = {\n  variant?: BaseVariations;\n  size?: ButtonSize | MQ<ButtonSize>;\n  /** Type is ignored if \"a\" is provided to \"as\" property. Note that you can explicetly pass null. */\n  type?: \"submit\" | \"button\" | \"reset\" | null;\n  disabled?: boolean;\n  /** When loading is true, disabled is set to true as well. */\n  loading?: boolean;\n  onClick?: (e: React.MouseEvent) => void;\n  onFocus?: (e: React.FocusEvent) => void;\n  onBlur?: (e: React.FocusEvent) => void;\n  leftIcon?: IconName;\n  rightIcon?: IconName;\n  fullWidth?: boolean;\n  destructive?: boolean;\n  privateProps?: ButtonPrivateProps;\n  \"data-e2e-test-id\"?: string;\n  /** Additional aria attributes. [see documentation](https://github.com/DefinitelyTyped/DefinitelyTyped/blob/02549c083e9d62b604091d770c4568d47282cdd0/types/react/index.d.ts#L1461)\n   */\n  ariaAttributes?: AriaAttributes;\n};\n\ntype ButtonComponent = <C extends React.ElementType = \"button\">(\n  props: PolymorphicComponentPropsWithRef<C, ButtonProps>\n) => React.ReactNode | null;\n\nfunction getLoaderIconColor(\n  variant: BaseVariations,\n  destructive: boolean\n): IconsColors {\n  switch (variant) {\n    case \"primary\":\n      return destructive ? \"error\" : \"accent\";\n    case \"secondary\":\n      return \"primary\";\n    default:\n      return destructive ? \"error\" : variant;\n  }\n}\n\nexport const Button: ButtonComponent = React.forwardRef(\n  <C extends React.ElementType = \"button\">(\n    {\n      \"data-e2e-test-id\": dataE2eTestId,\n      ariaAttributes,\n      as,\n      children,\n      disabled = false,\n      fullWidth = false,\n      destructive = false,\n      leftIcon,\n      loading = false,\n      onBlur,\n      onClick,\n      onFocus,\n      privateProps = { squareCorners: false },\n      rightIcon,\n      size = \"m\",\n      type = \"button\",\n      variant = \"primary\",\n      ...rest\n    }: PolymorphicComponentPropsWithRef<C, ButtonProps>,\n    ref?: PolymorphicRef<C>\n  ) => {\n    const { squareCorners, alignItems, rightIconVariant, rightIconColor } =\n      privateProps;\n\n    const handleClick = useCallback(\n      (e: React.MouseEvent) => {\n        if (disabled) {\n          e.preventDefault();\n        }\n        if (onClick) {\n          onClick(e);\n        }\n      },\n      [disabled, onClick]\n    );\n\n    const rightIconElm = rightIcon ? (\n      <Icon\n        size=\"s\"\n        name={rightIcon}\n        {...(rightIconVariant &&\n          !rightIconColor && { variant: rightIconVariant })}\n        {...(rightIconColor && { color: rightIconColor })}\n        data-testid={rightIcon}\n        data-e2e-test-id={rightIcon}\n        aria-hidden\n      />\n    ) : null;\n\n    const spacing = size === \"s\" ? \"xxs\" : \"xs\";\n\n    return (\n      <StyledButton\n        ref={ref}\n        data-e2e-test-id={dataE2eTestId}\n        data-ds-id=\"Button\"\n        // https://emotion.sh/docs/styled#as-prop\n        as={as}\n        disabled={disabled || loading}\n        loading={loading}\n        type={as && as !== \"button\" ? undefined : type}\n        fullWidth={fullWidth}\n        destructive={destructive}\n        squareCorners={squareCorners}\n        variant={variant}\n        size={size}\n        onClick={handleClick}\n        onFocus={onFocus}\n        onBlur={onBlur}\n        {...ariaAttributes}\n        {...rest}\n      >\n        {loading && (\n          <StyledLoaderWrap>\n            <StyledLoader>\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name=\"loader\"\n                color={getLoaderIconColor(variant, destructive)}\n                data-testid=\"loader\"\n                data-e2e-test-id=\"loader\"\n              />\n            </StyledLoader>\n          </StyledLoaderWrap>\n        )}\n        <StyledInner loading={loading}>\n          <Inline\n            vAlignItems=\"center\"\n            alignItems={alignItems || \"center\"}\n            space={spacing}\n            noWrap\n          >\n            {leftIcon && (\n              <Icon\n                aria-hidden\n                size=\"s\"\n                name={leftIcon}\n                data-testid={leftIcon}\n                data-e2e-test-id={leftIcon}\n              />\n            )}\n            {children}\n            {rightIconElm}\n          </Inline>\n        </StyledInner>\n      </StyledButton>\n    );\n  }\n);\n"],"names":[],"mappings":"AAuIqB"} */"),Button=_react.default.forwardRef(({"data-e2e-test-id":dataE2eTestId,ariaAttributes,as,children,disabled=!1,fullWidth=!1,destructive=!1,leftIcon,loading=!1,onBlur,onClick,onFocus,privateProps={squareCorners:!1},rightIcon,size="m",type="button",variant="primary",...rest},ref)=>{let{squareCorners,alignItems,rightIconVariant,rightIconColor}=privateProps,handleClick=(0,_react.useCallback)(e=>{disabled&&e.preventDefault(),onClick&&onClick(e)},[disabled,onClick]),rightIconElm=rightIcon?_react.default.createElement(_Icon.Icon,{size:"s",name:rightIcon,...rightIconVariant&&!rightIconColor&&{variant:rightIconVariant},...rightIconColor&&{color:rightIconColor},"data-testid":rightIcon,"data-e2e-test-id":rightIcon,"aria-hidden":!0}):null;return _react.default.createElement(StyledButton,{ref:ref,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"Button",as:as,disabled:disabled||loading,loading:loading,type:as&&"button"!==as?void 0:type,fullWidth:fullWidth,destructive:destructive,squareCorners:squareCorners,variant:variant,size:size,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,...ariaAttributes,...rest},loading&&_react.default.createElement(StyledLoaderWrap,null,_react.default.createElement(StyledLoader,null,_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:"loader",color:function(variant,destructive){switch(variant){case"primary":return destructive?"error":"accent";case"secondary":return"primary";default:return destructive?"error":variant}}(variant,destructive),"data-testid":"loader","data-e2e-test-id":"loader"}))),_react.default.createElement(StyledInner,{loading:loading},_react.default.createElement(_Inline.Inline,{vAlignItems:"center",alignItems:alignItems||"center",space:"s"===size?"xxs":"xs",noWrap:!0},leftIcon&&_react.default.createElement(_Icon.Icon,{"aria-hidden":!0,size:"s",name:leftIcon,"data-testid":leftIcon,"data-e2e-test-id":leftIcon}),children,rightIconElm)))});
@@ -0,0 +1,15 @@
1
+ import React from "react";
2
+ import { type BoxProps } from "../Box/Box";
3
+ import type { BaseVariations } from "../../types";
4
+ export type InteractiveBoxProps = BoxProps & {
5
+ destructive?: boolean;
6
+ disabled?: boolean;
7
+ fullWidth?: boolean;
8
+ onBlur?: (e: React.FocusEvent) => void;
9
+ onClick?: (e: React.MouseEvent | React.KeyboardEvent) => void;
10
+ onFocus?: (e: React.FocusEvent) => void;
11
+ onKeyDown?: (e: React.KeyboardEvent) => void;
12
+ tabIndex?: number;
13
+ variant?: BaseVariations;
14
+ };
15
+ export declare function InteractiveBox({ children, variant, disabled, onClick, onFocus, onBlur, fullWidth, destructive, space, vSpace, rSpace, lSpace, tSpace, bSpace, alignText, ariaAttributes, id, "data-e2e-test-id": dataE2eTestId, height, }: InteractiveBoxProps): React.ReactElement;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"InteractiveBox",{enumerable:!0,get:function(){return InteractiveBox}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_ispropvalid=/*#__PURE__*/_interop_require_default._(require("@emotion/is-prop-valid")),_Box=require("../Box/Box"),_mixins=require("../../shared/mixins"),StyledInteractiveBox=(0,_styled.default)(_Box.StyledBox,{shouldForwardProp:prop=>(0,_ispropvalid.default)(prop)&&"height"!==prop,target:"enlpgq70",label:"StyledInteractiveBox"})(({theme,variant,disabled,fullWidth,destructive})=>({...(0,_mixins.getButtonAppearanceReset)(),...(0,_mixins.getBaseButtonStyles)({theme}),...(0,_mixins.getPrimaryVariantStyles)({theme,destructive,disabled}),..."secondary"===variant&&{...(0,_mixins.getSecondaryVariantStyles)({theme,disabled,destructive})},..."tertiary"===variant&&(0,_mixins.getTertiaryVariantStyles)({theme,destructive,disabled}),...disabled&&{...(0,_mixins.getDisabledStyles)({theme}),cursor:"not-allowed"},...fullWidth&&{width:"100%"},...(0,_mixins.getFocusStyles)()}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvSW50ZXJhY3RpdmVCb3gvSW50ZXJhY3RpdmVCb3gudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9JbnRlcmFjdGl2ZUJveC9JbnRlcmFjdGl2ZUJveC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IHVzZUNhbGxiYWNrIH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgc3R5bGVkIGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBpc1Byb3BWYWxpZCBmcm9tIFwiQGVtb3Rpb24vaXMtcHJvcC12YWxpZFwiO1xuXG5pbXBvcnQgeyBTdHlsZWRCb3gsIHR5cGUgQm94UHJvcHMgfSBmcm9tIFwiLi4vQm94L0JveFwiO1xuaW1wb3J0IHR5cGUgeyBCYXNlVmFyaWF0aW9ucyB9IGZyb20gXCIuLi8uLi90eXBlc1wiO1xuaW1wb3J0IHtcbiAgZ2V0Rm9jdXNTdHlsZXMsXG4gIGdldERpc2FibGVkU3R5bGVzLFxuICBnZXRQcmltYXJ5VmFyaWFudFN0eWxlcyxcbiAgZ2V0U2Vjb25kYXJ5VmFyaWFudFN0eWxlcyxcbiAgZ2V0VGVydGlhcnlWYXJpYW50U3R5bGVzLFxuICBnZXRCdXR0b25BcHBlYXJhbmNlUmVzZXQsXG4gIGdldEJhc2VCdXR0b25TdHlsZXMsXG59IGZyb20gXCIuLi8uLi9zaGFyZWQvbWl4aW5zXCI7XG5cbmV4cG9ydCB0eXBlIEludGVyYWN0aXZlQm94UHJvcHMgPSBCb3hQcm9wcyAmIHtcbiAgZGVzdHJ1Y3RpdmU/OiBib29sZWFuO1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG4gIGZ1bGxXaWR0aD86IGJvb2xlYW47XG4gIG9uQmx1cj86IChlOiBSZWFjdC5Gb2N1c0V2ZW50KSA9PiB2b2lkO1xuICBvbkNsaWNrPzogKGU6IFJlYWN0Lk1vdXNlRXZlbnQgfCBSZWFjdC5LZXlib2FyZEV2ZW50KSA9PiB2b2lkO1xuICBvbkZvY3VzPzogKGU6IFJlYWN0LkZvY3VzRXZlbnQpID0+IHZvaWQ7XG4gIG9uS2V5RG93bj86IChlOiBSZWFjdC5LZXlib2FyZEV2ZW50KSA9PiB2b2lkO1xuICB0YWJJbmRleD86IG51bWJlcjtcbiAgdmFyaWFudD86IEJhc2VWYXJpYXRpb25zO1xufTtcblxuY29uc3QgU3R5bGVkSW50ZXJhY3RpdmVCb3ggPSBzdHlsZWQoU3R5bGVkQm94LCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT4gaXNQcm9wVmFsaWQocHJvcCkgJiYgcHJvcCAhPT0gXCJoZWlnaHRcIixcbn0pPEludGVyYWN0aXZlQm94UHJvcHM+KFxuICAoeyB0aGVtZSwgdmFyaWFudCwgZGlzYWJsZWQsIGZ1bGxXaWR0aCwgZGVzdHJ1Y3RpdmUgfSkgPT4gKHtcbiAgICAuLi5nZXRCdXR0b25BcHBlYXJhbmNlUmVzZXQoKSxcbiAgICAuLi5nZXRCYXNlQnV0dG9uU3R5bGVzKHsgdGhlbWUgfSksXG5cbiAgICAuLi5nZXRQcmltYXJ5VmFyaWFudFN0eWxlcyh7XG4gICAgICB0aGVtZSxcbiAgICAgIGRlc3RydWN0aXZlLFxuICAgICAgZGlzYWJsZWQsXG4gICAgfSksXG5cbiAgICAuLi4odmFyaWFudCA9PT0gXCJzZWNvbmRhcnlcIiAmJiB7XG4gICAgICAuLi5nZXRTZWNvbmRhcnlWYXJpYW50U3R5bGVzKHsgdGhlbWUsIGRpc2FibGVkLCBkZXN0cnVjdGl2ZSB9KSxcbiAgICB9KSxcblxuICAgIC4uLih2YXJpYW50ID09PSBcInRlcnRpYXJ5XCIgJiZcbiAgICAgIGdldFRlcnRpYXJ5VmFyaWFudFN0eWxlcyh7IHRoZW1lLCBkZXN0cnVjdGl2ZSwgZGlzYWJsZWQgfSkpLFxuXG4gICAgLi4uKGRpc2FibGVkICYmIHtcbiAgICAgIC4uLmdldERpc2FibGVkU3R5bGVzKHsgdGhlbWUgfSksXG4gICAgICBjdXJzb3I6IFwibm90LWFsbG93ZWRcIixcbiAgICB9KSxcblxuICAgIC4uLihmdWxsV2lkdGggJiYge1xuICAgICAgd2lkdGg6IFwiMTAwJVwiLFxuICAgIH0pLFxuICAgIC4uLmdldEZvY3VzU3R5bGVzKCksXG4gIH0pXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gSW50ZXJhY3RpdmVCb3goe1xuICBjaGlsZHJlbixcbiAgdmFyaWFudCA9IFwicHJpbWFyeVwiLFxuICBkaXNhYmxlZCxcbiAgb25DbGljayxcbiAgb25Gb2N1cyxcbiAgb25CbHVyLFxuICBmdWxsV2lkdGgsXG4gIGRlc3RydWN0aXZlLFxuICBzcGFjZSA9IFwiemVyb1wiLFxuICB2U3BhY2UsXG4gIHJTcGFjZSxcbiAgbFNwYWNlLFxuICB0U3BhY2UsXG4gIGJTcGFjZSxcbiAgYWxpZ25UZXh0LFxuICBhcmlhQXR0cmlidXRlcyxcbiAgaWQsXG4gIFwiZGF0YS1lMmUtdGVzdC1pZFwiOiBkYXRhRTJlVGVzdElkLFxuICBoZWlnaHQsXG59OiBJbnRlcmFjdGl2ZUJveFByb3BzKTogUmVhY3QuUmVhY3RFbGVtZW50IHtcbiAgY29uc3QgaGFuZGxlQ2xpY2sgPSB1c2VDYWxsYmFjayhcbiAgICAoZTogUmVhY3QuTW91c2VFdmVudCkgPT4ge1xuICAgICAgaWYgKGRpc2FibGVkKSB7XG4gICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgICAgaWYgKG9uQ2xpY2spIHtcbiAgICAgICAgb25DbGljayhlKTtcbiAgICAgIH1cbiAgICB9LFxuICAgIFtkaXNhYmxlZCwgb25DbGlja11cbiAgKTtcblxuICBjb25zdCBoYW5kbGVLZXlEb3duID0gdXNlQ2FsbGJhY2soXG4gICAgKGU6IFJlYWN0LktleWJvYXJkRXZlbnQpID0+IHtcbiAgICAgIGlmICgoZS5rZXkgPT09IFwiRW50ZXJcIiB8fCBlLmtleSA9PT0gXCIgXCIpICYmICFkaXNhYmxlZCkge1xuICAgICAgICBlLnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIGlmIChvbkNsaWNrKSB7XG4gICAgICAgICAgb25DbGljayhlKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0sXG4gICAgW2Rpc2FibGVkLCBvbkNsaWNrXVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPFN0eWxlZEludGVyYWN0aXZlQm94XG4gICAgICB2YXJpYW50PXt2YXJpYW50fVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgZnVsbFdpZHRoPXtmdWxsV2lkdGh9XG4gICAgICBkZXN0cnVjdGl2ZT17ZGVzdHJ1Y3RpdmV9XG4gICAgICBzcGFjZT17c3BhY2V9XG4gICAgICB2U3BhY2U9e3ZTcGFjZX1cbiAgICAgIHJTcGFjZT17clNwYWNlfVxuICAgICAgbFNwYWNlPXtsU3BhY2V9XG4gICAgICB0U3BhY2U9e3RTcGFjZX1cbiAgICAgIGJTcGFjZT17YlNwYWNlfVxuICAgICAgYWxpZ25UZXh0PXthbGlnblRleHR9XG4gICAgICByb2xlPVwiYnV0dG9uXCJcbiAgICAgIGlkPXtpZH1cbiAgICAgIGRhdGEtZTJlLXRlc3QtaWQ9e2RhdGFFMmVUZXN0SWR9XG4gICAgICBkYXRhLWRzLWlkPVwiSW50ZXJhY3RpdmVCb3hcIlxuICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICBvbkNsaWNrPXtoYW5kbGVDbGlja31cbiAgICAgIG9uRm9jdXM9e29uRm9jdXN9XG4gICAgICBvbkJsdXI9e29uQmx1cn1cbiAgICAgIG9uS2V5RG93bj17aGFuZGxlS2V5RG93bn1cbiAgICAgIHRhYkluZGV4PXtkaXNhYmxlZCA/IC0xIDogMH1cbiAgICAgIHsuLi5hcmlhQXR0cmlidXRlc31cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9TdHlsZWRJbnRlcmFjdGl2ZUJveD5cbiAgKTtcbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QjZCIn0= */");function InteractiveBox({children,variant="primary",disabled,onClick,onFocus,onBlur,fullWidth,destructive,space="zero",vSpace,rSpace,lSpace,tSpace,bSpace,alignText,ariaAttributes,id,"data-e2e-test-id":dataE2eTestId,height}){let handleClick=(0,_react.useCallback)(e=>{if(disabled)return void e.preventDefault();onClick&&onClick(e)},[disabled,onClick]),handleKeyDown=(0,_react.useCallback)(e=>{("Enter"===e.key||" "===e.key)&&!disabled&&(e.preventDefault(),onClick&&onClick(e))},[disabled,onClick]);return _react.default.createElement(StyledInteractiveBox,{variant:variant,disabled:disabled,fullWidth:fullWidth,destructive:destructive,space:space,vSpace:vSpace,rSpace:rSpace,lSpace:lSpace,tSpace:tSpace,bSpace:bSpace,alignText:alignText,role:"button",id:id,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"InteractiveBox",height:height,onClick:handleClick,onFocus:onFocus,onBlur:onBlur,onKeyDown:handleKeyDown,tabIndex:disabled?-1:0,...ariaAttributes},children)}
@@ -6,6 +6,7 @@ export { default as createCache } from "@emotion/cache";
6
6
  export * from "./components/Card/Card";
7
7
  export * from "./components/Card/CardBox";
8
8
  export * from "./components/Box/Box";
9
+ export * from "./components/InteractiveBox/InteractiveBox";
9
10
  export * from "./components/Inline/Inline";
10
11
  export * from "./components/Stack/Stack";
11
12
  export * from "./components/Typography/Header";
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Avatar/Avatar"),exports),_export_star._(require("./components/AvatarGroup/AvatarGroup"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports),_export_star._(require("./components/PromptInput/PromptInput"),exports),_export_star._(require("./components/ColorIndicator/ColorIndicator"),exports),_export_star._(require("./components/ColorPicker/ColorPicker"),exports),_export_star._(require("./components/NavBar/NavBar"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get CacheProvider(){return _react.CacheProvider},get ThemeProvider(){return _react.ThemeProvider},get createCache(){return _cache.default},get dark(){return dark},get light(){return light}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _export_star=require("@swc/helpers/_/_export_star"),_interop_require_default=require("@swc/helpers/_/_interop_require_default"),_visualConfig=require("./web-tokens/visualConfig"),_react=require("@emotion/react"),_cache=/*#__PURE__*/_interop_require_default._(require("@emotion/cache"));_export_star._(require("./components/Card/Card"),exports),_export_star._(require("./components/Card/CardBox"),exports),_export_star._(require("./components/Box/Box"),exports),_export_star._(require("./components/InteractiveBox/InteractiveBox"),exports),_export_star._(require("./components/Inline/Inline"),exports),_export_star._(require("./components/Stack/Stack"),exports),_export_star._(require("./components/Typography/Header"),exports),_export_star._(require("./components/Typography/Text"),exports),_export_star._(require("./components/Typography/TextClamped/TextClamped"),exports),_export_star._(require("./components/Typography/StyledText/StyledText"),exports),_export_star._(require("./components/Link/Link"),exports),_export_star._(require("./components/Icon/Icon"),exports),_export_star._(require("./components/Button/Button"),exports),_export_star._(require("./components/BulkActionsToolbar/BulkActionsToolbar"),exports),_export_star._(require("./components/Divider/Divider"),exports),_export_star._(require("./components/Column/Columns"),exports),_export_star._(require("./components/Form/SearchInput/SearchInput"),exports),_export_star._(require("./components/Tabs/Tabs"),exports),_export_star._(require("./components/Badge/Badge"),exports),_export_star._(require("./components/SearchResult/SearchResult"),exports),_export_star._(require("./components/Form/ToggleButton/ToggleButton"),exports),_export_star._(require("./components/DropdownMenu/DropdownMenu"),exports),_export_star._(require("./components/Form/FormFieldGroup/FormFieldGroup"),exports),_export_star._(require("./components/Form/Input"),exports),_export_star._(require("./components/Form/Checkbox/Checkbox"),exports),_export_star._(require("./components/Form/Toggle/Toggle"),exports),_export_star._(require("./components/Form/Radio/Radio"),exports),_export_star._(require("./components/Form/RadioButton/RadioButton"),exports),_export_star._(require("./components/Form/RangeInput/RangeInput"),exports),_export_star._(require("./components/Form/Textarea/Textarea"),exports),_export_star._(require("./components/Form/Combobox/Combobox"),exports),_export_star._(require("./components/SubThemeProvider/SubThemeProvider"),exports),_export_star._(require("./components/PictogramButton/PictogramButton"),exports),_export_star._(require("./components/MediaViewerBar/MediaViewerBar"),exports),_export_star._(require("./components/SegmentedProgressBar/SegmentedProgressBar"),exports),_export_star._(require("./components/ProgressBar/ProgressBar"),exports),_export_star._(require("./components/Container"),exports),_export_star._(require("./components/Form/PasswordInput"),exports),_export_star._(require("./components/RoundButton/RoundButton"),exports),_export_star._(require("./components/Notification/Notification"),exports),_export_star._(require("./components/Logo/Logo"),exports),_export_star._(require("./components/MediaItem"),exports),_export_star._(require("./components/Callout/Callout"),exports),_export_star._(require("./components/Patterns/Modal/Modal"),exports),_export_star._(require("./components/Patterns/ButtonGroup/ButtonGroup"),exports),_export_star._(require("./components/Collapsible/Collapsible"),exports),_export_star._(require("./components/LoadingSpinner/LoadingSpinner"),exports),_export_star._(require("./components/Pagination/Pagination"),exports),_export_star._(require("./components/DataTable"),exports),_export_star._(require("./components/Form/SegmentedControl/SegmentedControl"),exports),_export_star._(require("./components/Tooltip/Tooltip"),exports),_export_star._(require("./components/Tag/Tag"),exports),_export_star._(require("./components/TagGroup/TagGroup"),exports),_export_star._(require("./components/Toggletip/Toggletip"),exports),_export_star._(require("./components/Popover/Popover"),exports),_export_star._(require("./components/UserHighlightTooltip/UserHighlightTooltip"),exports),_export_star._(require("./components/Sheet/Sheet"),exports),_export_star._(require("./components/Image/Image"),exports),_export_star._(require("./components/Form/MaskedInput/MaskedInput"),exports),_export_star._(require("./components/Utilities/Expandable/Expandable"),exports),_export_star._(require("./components/QBankRichText/QBankRichText"),exports),_export_star._(require("./components/Tutorialtip/Tutorialtip"),exports),_export_star._(require("./components/EntityTree"),exports),_export_star._(require("./components/EntityList"),exports),_export_star._(require("./components/Form/Select"),exports),_export_star._(require("./components/BinaryFeedback/BinaryFeedback"),exports),_export_star._(require("./components/Grid/Grid"),exports),_export_star._(require("./components/AccessCardItem/AccessCardItem"),exports),_export_star._(require("./components/Avatar/Avatar"),exports),_export_star._(require("./components/AvatarGroup/AvatarGroup"),exports),_export_star._(require("./components/Toast"),exports),_export_star._(require("./components/Form/DateInput/DateInput"),exports),_export_star._(require("./components/CheckboxCard/CheckboxCard"),exports),_export_star._(require("./components/RadioCard/RadioCard"),exports),_export_star._(require("./components/Utilities/ContainerQuery/ContainerQuery"),exports),_export_star._(require("./components/Utilities/ScreenReaderText/ScreenReaderText"),exports),_export_star._(require("./components/CatalogCard/CatalogCard"),exports),_export_star._(require("./components/MediaViewerCarousel/MediaViewerCarousel"),exports),_export_star._(require("./components/PromptInput/PromptInput"),exports),_export_star._(require("./components/ColorIndicator/ColorIndicator"),exports),_export_star._(require("./components/ColorPicker/ColorPicker"),exports),_export_star._(require("./components/NavBar/NavBar"),exports);const{dark,light}=_visualConfig.ambossVisualConfiguration;
@@ -0,0 +1,7 @@
1
+ import type { CSSObject, Theme } from "@emotion/react";
2
+ import type { ButtonProps } from "../../components/Button/Button";
3
+ type BaseButtonStylesProps = {
4
+ theme: Theme;
5
+ } & Pick<ButtonProps, "size">;
6
+ export declare function getBaseButtonStyles({ theme, size, }: BaseButtonStylesProps): CSSObject;
7
+ export {};
@@ -0,0 +1 @@
1
+ "use strict";function getBaseButtonStyles({theme,size}){return{borderRadius:theme.variables.size.borderRadius.xs,fontFamily:theme.variables.fontFamily.lato,fontSize:theme.variables.size.font.s,lineHeight:theme.variables.size.lineHeight.xs,fontWeight:theme.variables.weight.bold,cursor:"pointer",userSelect:"none",..."s"===size&&{padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`},..."m"===size&&{padding:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},..."l"===size&&{padding:`${theme.variables.size.spacing.m} ${theme.variables.size.spacing.xl}`}}}Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"getBaseButtonStyles",{enumerable:!0,get:function(){return getBaseButtonStyles}});
@@ -0,0 +1,2 @@
1
+ import type { CSSObject } from "@emotion/react";
2
+ export declare function getButtonAppearanceReset(): CSSObject;
@@ -0,0 +1 @@
1
+ "use strict";function getButtonAppearanceReset(){return{"&[type='button']":{appearance:"none",MozAppearance:"none",WebkitAppearance:"none"},display:"inline-block",border:0,margin:0,textTransform:"none",textDecoration:"none"}}Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"getButtonAppearanceReset",{enumerable:!0,get:function(){return getButtonAppearanceReset}});
@@ -0,0 +1,6 @@
1
+ import type { CSSObject, Theme } from "@emotion/react";
2
+ type DisabledStylesProps = {
3
+ theme: Theme;
4
+ };
5
+ export declare function getDisabledStyles({ theme }: DisabledStylesProps): CSSObject;
6
+ export {};
@@ -0,0 +1 @@
1
+ "use strict";function getDisabledStyles({theme}){return{opacity:theme.variables.opacity.disabled,cursor:"not-allowed"}}Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"getDisabledStyles",{enumerable:!0,get:function(){return getDisabledStyles}});
@@ -0,0 +1,2 @@
1
+ import type { CSSObject } from "@emotion/react";
2
+ export declare function getFocusStyles(): CSSObject;
@@ -0,0 +1 @@
1
+ "use strict";function getFocusStyles(){return{"&:focus-visible":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}}}Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"getFocusStyles",{enumerable:!0,get:function(){return getFocusStyles}});
@@ -0,0 +1,9 @@
1
+ import type { CSSObject, Theme } from "@emotion/react";
2
+ import type { ButtonProps } from "../../components/Button/Button";
3
+ type VariantProps = Pick<ButtonProps, "disabled" | "destructive" | "size"> & {
4
+ theme: Theme;
5
+ };
6
+ export declare function getPrimaryVariantStyles({ theme, destructive, disabled, }: VariantProps): CSSObject;
7
+ export declare function getSecondaryVariantStyles({ theme, disabled, size, }: VariantProps): CSSObject;
8
+ export declare function getTertiaryVariantStyles({ theme, destructive, disabled, size, }: VariantProps): CSSObject;
9
+ export {};
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get getPrimaryVariantStyles(){return getPrimaryVariantStyles},get getSecondaryVariantStyles(){return getSecondaryVariantStyles},get getTertiaryVariantStyles(){return getTertiaryVariantStyles}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});function getPrimaryVariantStyles({theme,destructive,disabled}){return{backgroundColor:destructive?theme.values.color.background.error.default:theme.values.color.background.accent.default,color:theme.values.color.text.onAccent.default,...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.background.error.hover:theme.values.color.background.accent.hover},"&:active":{backgroundColor:destructive?theme.values.color.background.error.active:theme.values.color.background.accent.active}}}}function getSecondaryVariantStyles({theme,disabled,size}){return{border:"1px solid",backgroundColor:theme.values.color.background.transparent.default,borderColor:theme.values.color.border.primary.default,color:theme.values.color.text.secondary.default,...!disabled&&{"&:hover":{borderColor:theme.values.color.border.primary.hover,backgroundColor:theme.values.color.background.transparent.hover},"&:active":{backgroundColor:theme.values.color.background.transparent.active,borderColor:theme.values.color.border.primary.active}},..."s"===size&&{padding:`${parseInt(theme.variables.size.spacing.xs,10)-1}px ${parseInt(theme.variables.size.spacing.m,10)-1}px`},..."m"===size&&{padding:`${parseInt(theme.variables.size.spacing.s,10)-1}px ${parseInt(theme.variables.size.spacing.l,10)-1}px`},..."l"===size&&{padding:`${parseInt(theme.variables.size.spacing.m,10)-1}px ${parseInt(theme.variables.size.spacing.xl,10)-1}px`}}}function getTertiaryVariantStyles({theme,destructive,disabled,size}){return{color:destructive?theme.values.color.text.error.default:theme.values.color.text.secondary.default,backgroundColor:theme.values.color.background.transparent.default,...!disabled&&{"&:hover":{backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.hover:theme.values.color.background.transparent.hover},"&:active":{color:destructive?theme.values.color.text.error.default:theme.values.color.text.primary.default,backgroundColor:destructive?theme.values.color.destructiveTertiaryButton.background.active:theme.values.color.background.transparent.active}},..."s"===size&&{padding:theme.variables.size.spacing.xs},..."m"===size&&{padding:theme.variables.size.spacing.s},..."l"===size&&{padding:theme.variables.size.spacing.m}}}
@@ -0,0 +1,5 @@
1
+ export { getFocusStyles } from "./getFocusStyles";
2
+ export { getDisabledStyles } from "./getDisabledStyles";
3
+ export { getButtonAppearanceReset } from "./getButtonAppearanceReset";
4
+ export { getBaseButtonStyles } from "./getBaseButtonStyles";
5
+ export { getPrimaryVariantStyles, getSecondaryVariantStyles, getTertiaryVariantStyles, } from "./getVariantStyles";
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var target=exports,all={get getBaseButtonStyles(){return _getBaseButtonStyles.getBaseButtonStyles},get getButtonAppearanceReset(){return _getButtonAppearanceReset.getButtonAppearanceReset},get getDisabledStyles(){return _getDisabledStyles.getDisabledStyles},get getFocusStyles(){return _getFocusStyles.getFocusStyles},get getPrimaryVariantStyles(){return _getVariantStyles.getPrimaryVariantStyles},get getSecondaryVariantStyles(){return _getVariantStyles.getSecondaryVariantStyles},get getTertiaryVariantStyles(){return _getVariantStyles.getTertiaryVariantStyles}};for(var name in all)Object.defineProperty(target,name,{enumerable:!0,get:Object.getOwnPropertyDescriptor(all,name).get});const _getFocusStyles=require("./getFocusStyles"),_getDisabledStyles=require("./getDisabledStyles"),_getButtonAppearanceReset=require("./getButtonAppearanceReset"),_getBaseButtonStyles=require("./getBaseButtonStyles"),_getVariantStyles=require("./getVariantStyles");