react-magma-dom 4.11.0-next.13 → 4.11.0-next.14

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.
@@ -2187,45 +2187,60 @@ function buildNoSpaceBorderColor(props) {
2187
2187
  return props.theme.colors.neutral100;
2188
2188
  }
2189
2189
  var _ref$1 = {
2190
- name: "7z3zmz-StyledButtonGroup",
2191
- styles: "&:first-child{margin-top:0;}&:last-child{margin-bottom:0;};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8FQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
2190
+ name: "ylk48c-StyledButtonGroup",
2191
+ styles: "&:first-child:not(:only-child){>div>div>button,>div>button,>button{margin-top:0;}}&:last-child:not(:only-child){>div>div>button,>div>button,>button{margin-bottom:0;}};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoJQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
2192
2192
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
2193
2193
  };
2194
2194
  var _ref2 = {
2195
- name: "zegd7n-StyledButtonGroup",
2196
- styles: "&:first-child{margin-left:0;}&:last-child{margin-right:0;};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoFQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
2195
+ name: "1ss8hcx-StyledButtonGroup",
2196
+ styles: "&:first-child:not(:only-child){>div>div>button,>div>button,>button{margin-left:0;}}&:last-child:not(:only-child){>div>div>button,>div>button,>button{margin-right:0;}};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiIQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
2197
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
2198
+ };
2199
+ var _ref3 = {
2200
+ name: "1hsqb3r-StyledButtonGroup",
2201
+ styles: "&:not([aria-label]):not([title]){width:100%;}&[aria-label]:empty,&[title]:empty{width:auto;flex:none;}&:has(svg):not(:has(:not(svg))){width:auto;flex:none;};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8GQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
2197
2202
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
2198
2203
  };
2199
2204
  var StyledButtonGroup = /*#__PURE__*/_styled("div", {
2200
- target: "encm85s0",
2205
+ target: "encm85s1",
2201
2206
  label: "StyledButtonGroup"
2202
- })("display:flex;justify-content:", function (props) {
2207
+ })("list-style:none;margin:0;padding:0;display:flex;justify-content:", function (props) {
2203
2208
  return buildButtonAlignment(props);
2204
2209
  }, ";flex-direction:", function (props) {
2205
2210
  return props.orientation === exports.ButtonGroupOrientation.vertical ? 'column' : 'row';
2206
2211
  }, ";flex-wrap:wrap;", function (props) {
2207
- return props.orientation === exports.ButtonGroupOrientation.vertical && /*#__PURE__*/react.css("align-items:", buildButtonAlignment(props), ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAyEQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2208
- }, " ", function (props) {
2209
- return props.orientation === exports.ButtonGroupOrientation.horizontal && /*#__PURE__*/react.css("row-gap:", props.theme.spaceScale.spacing03, ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2210
- }, ">button,>div{", function (props) {
2211
- return props.orientation === exports.ButtonGroupOrientation.horizontal && _ref2;
2212
+ return props.orientation === exports.ButtonGroupOrientation.vertical && /*#__PURE__*/react.css("align-items:", buildButtonAlignment(props), ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2212
2213
  }, " ", function (props) {
2213
- return props.orientation === exports.ButtonGroupOrientation.vertical && _ref$1;
2214
- }, ";}>div{margin:", function (props) {
2214
+ return props.orientation === exports.ButtonGroupOrientation.horizontal && /*#__PURE__*/react.css("row-gap:", props.theme.spaceScale.spacing03, ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiFQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2215
+ }, ">li>div{margin:", function (props) {
2215
2216
  return buildButtonMargin(props);
2216
2217
  }, ";flex:", function (props) {
2217
2218
  return props.alignment === exports.ButtonGroupAlignment.fill && props.orientation === exports.ButtonGroupOrientation.horizontal ? '1' : 'none';
2218
- }, ";", function (props) {
2219
- return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css("&:first-child:not(:only-child){button{border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}}&:nth-child(2){button{border-left:1px solid ", buildNoSpaceBorderColor(props), ";}}&:not(:first-child){button{border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}}&:not(:first-child)&:not(:last-child){button{border-right:0;}}&:last-child:not(:only-child){button{border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";}};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0HQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2220
- }, ";button{width:", function (props) {
2219
+ }, ";div>button,button{width:", function (props) {
2221
2220
  return props.alignment === exports.ButtonGroupAlignment.fill ? '100%' : '';
2222
- }, ";&:nth-child(2){width:40px;}}}>button{margin:", function (props) {
2221
+ }, ";&:nth-child(2){width:40px;}}}>li>button{margin:", function (props) {
2223
2222
  return buildButtonMargin(props);
2224
2223
  }, ";flex:", function (props) {
2225
2224
  return props.alignment === exports.ButtonGroupAlignment.fill && props.orientation === exports.ButtonGroupOrientation.horizontal ? '1' : 'none';
2226
2225
  }, ";", function (props) {
2227
- return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css("&:first-child:not(:only-child){border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}&:nth-child(2){border-left:1px solid ", buildNoSpaceBorderColor(props), ";}&:not(:first-child){border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}&:not(:first-child)&:not(:last-child){border-right:0;}&:last-child:not(:only-child){border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2KQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2228
- }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkEqC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2226
+ return props.alignment === exports.ButtonGroupAlignment.fill && _ref3;
2227
+ }, ";}>li{", function (props) {
2228
+ return props.orientation === exports.ButtonGroupOrientation.horizontal && _ref2;
2229
+ }, " ", function (props) {
2230
+ return props.orientation === exports.ButtonGroupOrientation.vertical && _ref$1;
2231
+ }, " ", function (props) {
2232
+ return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css("&:first-child:not(:only-child){>div>div>button,>div>button,>button{border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}}&:nth-child(2){>div>div>button,>div>button,>button{border-left:1px solid ", buildNoSpaceBorderColor(props), ";}}&:not(:first-child){>div>div>button,>div>button,>button{border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}}&:not(:first-child)&:not(:last-child){>div>div>button,>div>button,>button{border-right:0;}}&:last-child:not(:only-child){>div>div>button,>div>button,>button{border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";}};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0KQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2233
+ }, ";", function (props) {
2234
+ return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css(">div{&:first-child:not(:only-child){div>button,button{border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}}&:nth-child(2){div>button,button{border-left:1px solid ", buildNoSpaceBorderColor(props), ";}}&:not(:first-child){div>button,button{border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}}&:not(:first-child)&:not(:last-child){div>button,button{border-right:0;}}&:last-child:not(:only-child){div>button,button{border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";}}};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4NQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2235
+ }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkEqC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
2236
+ var StyledButtonItem = /*#__PURE__*/_styled("li", {
2237
+ target: "encm85s0",
2238
+ label: "StyledButtonItem"
2239
+ })( {
2240
+ name: "dy2mza",
2241
+ styles: "list-style:none;margin:0;padding:0;display:contents/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAwQmC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
2242
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
2243
+ });
2229
2244
  var ButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
2230
2245
  var alignment = props.alignment,
2231
2246
  children = props.children,
@@ -2246,6 +2261,9 @@ var ButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
2246
2261
  isInverse: isInverse
2247
2262
  };
2248
2263
  var theme = React.useContext(ThemeContext);
2264
+ var wrappedChildren = React.Children.map(children, function (child) {
2265
+ return React.createElement(StyledButtonItem, null, child);
2266
+ });
2249
2267
  return React.createElement(StyledButtonGroup, Object.assign({
2250
2268
  alignment: alignment || exports.ButtonGroupAlignment.left,
2251
2269
  color: color || exports.ButtonColor.primary,
@@ -2256,9 +2274,12 @@ var ButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
2256
2274
  theme: theme,
2257
2275
  ref: ref,
2258
2276
  "data-testid": testId
2259
- }, rest), React.createElement(ButtonGroupContext.Provider, {
2277
+ }, rest, {
2278
+ as: 'ul',
2279
+ role: "list"
2280
+ }), React.createElement(ButtonGroupContext.Provider, {
2260
2281
  value: context
2261
- }, children));
2282
+ }, wrappedChildren));
2262
2283
  });
2263
2284
 
2264
2285
  var DEFAULT_STYLE_PROPS$1 = {