react-magma-dom 4.12.0-next.6 → 4.12.0-next.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/index.js +81 -28
- package/dist/esm/index.js.map +1 -1
- package/dist/properties.json +303 -212
- package/dist/react-magma-dom.cjs.development.js +71 -24
- package/dist/react-magma-dom.cjs.development.js.map +1 -1
- package/dist/react-magma-dom.cjs.production.min.js +1 -1
- package/dist/react-magma-dom.cjs.production.min.js.map +1 -1
- package/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -3548,52 +3548,99 @@ function buildNoSpaceBorderColor(props) {
|
|
|
3548
3548
|
}
|
|
3549
3549
|
return props.theme.colors.neutral100;
|
|
3550
3550
|
}
|
|
3551
|
-
|
|
3552
|
-
|
|
3553
|
-
|
|
3551
|
+
function buildFlex(props) {
|
|
3552
|
+
return props.alignment === ButtonGroupAlignment.fill && props.orientation === ButtonGroupOrientation.horizontal ? '1' : 'none';
|
|
3553
|
+
}
|
|
3554
|
+
function buildBorderRight(props) {
|
|
3555
|
+
return props.color === ButtonColor.secondary || props.color === ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100;
|
|
3556
|
+
}
|
|
3557
|
+
var buildNoSpaceButtonStyles = function buildNoSpaceButtonStyles(props, selector) {
|
|
3558
|
+
if (selector === void 0) {
|
|
3559
|
+
selector = '';
|
|
3560
|
+
}
|
|
3561
|
+
var selectorWrapper = function selectorWrapper(styles) {
|
|
3562
|
+
return selector ? selector + " { " + styles + " }" : styles;
|
|
3563
|
+
};
|
|
3564
|
+
return /*#__PURE__*/css("&:first-child:not(:only-child){", selectorWrapper("\n border-radius: " + props.theme.borderRadius + " 0 0 " + props.theme.borderRadius + ";\n border-right: 0;\n "), ";}&:nth-child(2){", selectorWrapper("\n border-left: 1px solid " + buildNoSpaceBorderColor(props) + ";\n "), ";}&:not(:first-child){", selectorWrapper("\n border-radius: 0;\n border-right: " + buildBorderRight(props) + ";\n "), ";}&:not(:first-child)&:not(:last-child){", selectorWrapper("\n border-right: 0;\n "), ";}&:last-child:not(:only-child){", selectorWrapper("\n border-radius: 0 " + props.theme.borderRadius + " " + props.theme.borderRadius + " 0;\n border-right: 1px solid " + buildNoSpaceBorderColor(props) + ";\n "), ";};label:buildNoSpaceButtonStyles;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAgFe","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */"));
|
|
3565
|
+
};
|
|
3566
|
+
var _ref3 = process.env.NODE_ENV === "production" ? {
|
|
3567
|
+
name: "1tsdy6v-buildHorizontalMarginReset",
|
|
3568
|
+
styles: "&:first-child:not(:only-child){>button{margin-left:0;}}&:last-child:not(:only-child){>button{margin-right:0;}};label:buildHorizontalMarginReset;"
|
|
3554
3569
|
} : {
|
|
3555
|
-
name: "
|
|
3556
|
-
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"]} */",
|
|
3570
|
+
name: "1tsdy6v-buildHorizontalMarginReset",
|
|
3571
|
+
styles: "&:first-child:not(:only-child){>button{margin-left:0;}}&:last-child:not(:only-child){>button{margin-right:0;}};label:buildHorizontalMarginReset;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+G6C","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */",
|
|
3557
3572
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
3558
3573
|
};
|
|
3574
|
+
var buildHorizontalMarginReset = function buildHorizontalMarginReset() {
|
|
3575
|
+
return _ref3;
|
|
3576
|
+
};
|
|
3559
3577
|
var _ref2 = process.env.NODE_ENV === "production" ? {
|
|
3560
|
-
name: "
|
|
3561
|
-
styles: "&:first-child{margin-
|
|
3578
|
+
name: "1a9y4w2-buildVerticalMarginReset",
|
|
3579
|
+
styles: "&:first-child:not(:only-child){>button{margin-top:0;}}&:last-child:not(:only-child){>button{margin-bottom:0;}};label:buildVerticalMarginReset;"
|
|
3562
3580
|
} : {
|
|
3563
|
-
name: "
|
|
3564
|
-
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"]} */",
|
|
3581
|
+
name: "1a9y4w2-buildVerticalMarginReset",
|
|
3582
|
+
styles: "&:first-child:not(:only-child){>button{margin-top:0;}}&:last-child:not(:only-child){>button{margin-bottom:0;}};label:buildVerticalMarginReset;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4H2C","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */",
|
|
3583
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
3584
|
+
};
|
|
3585
|
+
var buildVerticalMarginReset = function buildVerticalMarginReset() {
|
|
3586
|
+
return _ref2;
|
|
3587
|
+
};
|
|
3588
|
+
function shouldApplyNoSpaceStyles(props) {
|
|
3589
|
+
return props.noSpace && props.orientation === ButtonGroupOrientation.horizontal && props.variant === ButtonVariant.solid && props.alignment !== ButtonGroupAlignment.apart;
|
|
3590
|
+
}
|
|
3591
|
+
var _ref$2 = process.env.NODE_ENV === "production" ? {
|
|
3592
|
+
name: "1hsqb3r-StyledButtonGroup",
|
|
3593
|
+
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;"
|
|
3594
|
+
} : {
|
|
3595
|
+
name: "1hsqb3r-StyledButtonGroup",
|
|
3596
|
+
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":"AAqLQ","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */",
|
|
3565
3597
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
3566
3598
|
};
|
|
3567
3599
|
var StyledButtonGroup = /*#__PURE__*/_styled("div", {
|
|
3568
|
-
target: "
|
|
3600
|
+
target: "encm85s1",
|
|
3569
3601
|
label: "StyledButtonGroup"
|
|
3570
|
-
})("display:flex;justify-content:", function (props) {
|
|
3602
|
+
})("list-style:none;margin:0;padding:0;display:flex;justify-content:", function (props) {
|
|
3571
3603
|
return buildButtonAlignment(props);
|
|
3572
3604
|
}, ";flex-direction:", function (props) {
|
|
3573
3605
|
return props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row';
|
|
3574
3606
|
}, ";flex-wrap:wrap;", function (props) {
|
|
3575
|
-
return props.orientation === ButtonGroupOrientation.vertical && /*#__PURE__*/css("align-items:", buildButtonAlignment(props), ";;label:StyledButtonGroup;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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"]} */"));
|
|
3576
|
-
}, " ", function (props) {
|
|
3577
|
-
return props.orientation === ButtonGroupOrientation.horizontal && /*#__PURE__*/css("row-gap:", props.theme.spaceScale.spacing03, ";;label:StyledButtonGroup;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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"]} */"));
|
|
3578
|
-
}, ">button,>div{", function (props) {
|
|
3579
|
-
return props.orientation === ButtonGroupOrientation.horizontal && _ref2;
|
|
3607
|
+
return props.orientation === ButtonGroupOrientation.vertical && /*#__PURE__*/css("align-items:", buildButtonAlignment(props), ";;label:StyledButtonGroup;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAyJQ","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */"));
|
|
3580
3608
|
}, " ", function (props) {
|
|
3581
|
-
return props.orientation === ButtonGroupOrientation.vertical && _ref$2;
|
|
3582
|
-
}, "
|
|
3609
|
+
return props.orientation === ButtonGroupOrientation.horizontal && /*#__PURE__*/css("row-gap:", props.theme.spaceScale.spacing03, ";;label:StyledButtonGroup;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8JQ","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */"));
|
|
3610
|
+
}, ">li>div{margin:", function (props) {
|
|
3583
3611
|
return buildButtonMargin(props);
|
|
3584
3612
|
}, ";flex:", function (props) {
|
|
3585
|
-
return props
|
|
3586
|
-
}, ";", function (props) {
|
|
3587
|
-
return props.noSpace && props.orientation === ButtonGroupOrientation.horizontal && props.variant === ButtonVariant.solid && props.alignment !== ButtonGroupAlignment.apart && /*#__PURE__*/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 === ButtonColor.secondary || props.color === 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;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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"]} */"));
|
|
3588
|
-
}, ";button{width:", function (props) {
|
|
3613
|
+
return buildFlex(props);
|
|
3614
|
+
}, ";div>button,button{width:", function (props) {
|
|
3589
3615
|
return props.alignment === ButtonGroupAlignment.fill ? '100%' : '';
|
|
3590
|
-
}, ";&:nth-child(2){width:40px;}}}>button{margin:", function (props) {
|
|
3616
|
+
}, ";&:nth-child(2){width:40px;}}}>li>button{margin:", function (props) {
|
|
3591
3617
|
return buildButtonMargin(props);
|
|
3592
3618
|
}, ";flex:", function (props) {
|
|
3593
|
-
return props
|
|
3619
|
+
return buildFlex(props);
|
|
3620
|
+
}, ";", function (props) {
|
|
3621
|
+
return props.alignment === ButtonGroupAlignment.fill && _ref$2;
|
|
3622
|
+
}, ";}>li{", function (props) {
|
|
3623
|
+
return props.orientation === ButtonGroupOrientation.horizontal && buildHorizontalMarginReset();
|
|
3624
|
+
}, " ", function (props) {
|
|
3625
|
+
return props.orientation === ButtonGroupOrientation.vertical && buildVerticalMarginReset();
|
|
3626
|
+
}, " ", function (props) {
|
|
3627
|
+
return shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props, 'button');
|
|
3594
3628
|
}, ";", function (props) {
|
|
3595
|
-
return props.noSpace && props.orientation === ButtonGroupOrientation.horizontal && props.variant === ButtonVariant.solid && props.alignment !== ButtonGroupAlignment.apart && /*#__PURE__*/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 === ButtonColor.secondary || props.color === 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;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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"]} */"));
|
|
3596
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# 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"]} */"));
|
|
3629
|
+
return shouldApplyNoSpaceStyles(props) && /*#__PURE__*/css(">div{", buildNoSpaceButtonStyles(props, 'button'), ";};label:StyledButtonGroup;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiNQ","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */"));
|
|
3630
|
+
}, ";}>li>button{", function (props) {
|
|
3631
|
+
return shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props);
|
|
3632
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA+IqC","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */"));
|
|
3633
|
+
var StyledButtonItem = /*#__PURE__*/_styled("li", {
|
|
3634
|
+
target: "encm85s0",
|
|
3635
|
+
label: "StyledButtonItem"
|
|
3636
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
3637
|
+
name: "dy2mza",
|
|
3638
|
+
styles: "list-style:none;margin:0;padding:0;display:contents"
|
|
3639
|
+
} : {
|
|
3640
|
+
name: "dy2mza",
|
|
3641
|
+
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":"AA6NmC","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\nfunction buildFlex(props) {\r\n    return props.alignment === ButtonGroupAlignment.fill &&\r\n        props.orientation === ButtonGroupOrientation.horizontal\r\n        ? '1'\r\n        : 'none';\r\n}\r\nfunction buildBorderRight(props) {\r\n    return props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`;\r\n}\r\nconst buildNoSpaceButtonStyles = (props, selector = '') => {\r\n    const selectorWrapper = (styles) => selector ? `${selector} { ${styles} }` : styles;\r\n    return css `\n    &:first-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: ${props.theme.borderRadius} 0 0 ${props.theme.borderRadius};\n        border-right: 0;\n      `)}\n    }\n    &:nth-child(2) {\n      ${selectorWrapper(`\n        border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n    &:not(:first-child) {\n      ${selectorWrapper(`\n        border-radius: 0;\n        border-right: ${buildBorderRight(props)};\n      `)}\n    }\n    &:not(:first-child)&:not(:last-child) {\n      ${selectorWrapper(`\n        border-right: 0;\n      `)}\n    }\n    &:last-child:not(:only-child) {\n      ${selectorWrapper(`\n        border-radius: 0 ${props.theme.borderRadius} ${props.theme.borderRadius} 0;\n        border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n      `)}\n    }\n  `;\r\n};\r\nconst buildHorizontalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-left: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-right: 0;\n    }\n  }\n`;\r\nconst buildVerticalMarginReset = () => css `\n  &:first-child:not(:only-child) {\n    > button {\n      margin-top: 0;\n    }\n  }\n\n  &:last-child:not(:only-child) {\n    > button {\n      margin-bottom: 0;\n    }\n  }\n`;\r\nfunction shouldApplyNoSpaceStyles(props) {\r\n    return (props.noSpace &&\r\n        props.orientation === ButtonGroupOrientation.horizontal &&\r\n        props.variant === ButtonVariant.solid &&\r\n        props.alignment !== ButtonGroupAlignment.apart);\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 => buildFlex(props)};\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 => buildFlex(props)};\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    buildHorizontalMarginReset()}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    buildVerticalMarginReset()}\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    buildNoSpaceButtonStyles(props, 'button')};\n\n    ${props => shouldApplyNoSpaceStyles(props) &&\r\n    css `\n        > div {\n          ${buildNoSpaceButtonStyles(props, 'button')}\n        }\n      `};\n  }\n\n  // Styles for ToggleButtonGroup\n  > li > button {\n    ${props => shouldApplyNoSpaceStyles(props) && buildNoSpaceButtonStyles(props)};\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"]} */",
|
|
3642
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
3643
|
+
});
|
|
3597
3644
|
var ButtonGroup = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
3598
3645
|
var alignment = props.alignment,
|
|
3599
3646
|
children = props.children,
|
|
@@ -3614,6 +3661,9 @@ var ButtonGroup = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
3614
3661
|
isInverse: isInverse
|
|
3615
3662
|
};
|
|
3616
3663
|
var theme = useContext(ThemeContext);
|
|
3664
|
+
var wrappedChildren = Children.map(children, function (child) {
|
|
3665
|
+
return createElement(StyledButtonItem, null, child);
|
|
3666
|
+
});
|
|
3617
3667
|
return createElement(StyledButtonGroup, Object.assign({
|
|
3618
3668
|
alignment: alignment || ButtonGroupAlignment.left,
|
|
3619
3669
|
color: color || ButtonColor.primary,
|
|
@@ -3624,9 +3674,12 @@ var ButtonGroup = /*#__PURE__*/forwardRef(function (props, ref) {
|
|
|
3624
3674
|
theme: theme,
|
|
3625
3675
|
ref: ref,
|
|
3626
3676
|
"data-testid": testId
|
|
3627
|
-
}, rest
|
|
3677
|
+
}, rest, {
|
|
3678
|
+
as: 'ul',
|
|
3679
|
+
role: "list"
|
|
3680
|
+
}), createElement(ButtonGroupContext.Provider, {
|
|
3628
3681
|
value: context
|
|
3629
|
-
},
|
|
3682
|
+
}, wrappedChildren));
|
|
3630
3683
|
});
|
|
3631
3684
|
|
|
3632
3685
|
var _excluded$5 = ["variant", "shape", "size", "testId", "textTransform"];
|