react-magma-dom 5.1.0-rc.14 → 5.1.0-rc.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/index.js +69 -37
- package/dist/esm/index.js.map +1 -1
- package/dist/react-magma-dom.cjs.development.js +58 -32
- 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
|
@@ -2187,45 +2187,60 @@ function buildNoSpaceBorderColor(props) {
|
|
|
2187
2187
|
return props.theme.colors.neutral100;
|
|
2188
2188
|
}
|
|
2189
2189
|
var _ref$1 = {
|
|
2190
|
-
name: "
|
|
2191
|
-
styles: "&:first-child{margin-top:0;}&:last-child{margin-bottom:0;};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8FQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
2190
|
+
name: "ylk48c-StyledButtonGroup",
|
|
2191
|
+
styles: "&:first-child:not(:only-child){>div>div>button,>div>button,>button{margin-top:0;}}&:last-child:not(:only-child){>div>div>button,>div>button,>button{margin-bottom:0;}};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoJQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
2192
2192
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
2193
2193
|
};
|
|
2194
2194
|
var _ref2 = {
|
|
2195
|
-
name: "
|
|
2196
|
-
styles: "&:first-child{margin-left:0;}&:last-child{margin-right:0;};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAoFQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
2195
|
+
name: "1ss8hcx-StyledButtonGroup",
|
|
2196
|
+
styles: "&:first-child:not(:only-child){>div>div>button,>div>button,>button{margin-left:0;}}&:last-child:not(:only-child){>div>div>button,>div>button,>button{margin-right:0;}};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiIQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
2197
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
2198
|
+
};
|
|
2199
|
+
var _ref3 = {
|
|
2200
|
+
name: "1hsqb3r-StyledButtonGroup",
|
|
2201
|
+
styles: "&:not([aria-label]):not([title]){width:100%;}&[aria-label]:empty,&[title]:empty{width:auto;flex:none;}&:has(svg):not(:has(:not(svg))){width:auto;flex:none;};label:StyledButtonGroup;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8GQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
2197
2202
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
2198
2203
|
};
|
|
2199
2204
|
var StyledButtonGroup = /*#__PURE__*/_styled("div", {
|
|
2200
|
-
target: "
|
|
2205
|
+
target: "encm85s1",
|
|
2201
2206
|
label: "StyledButtonGroup"
|
|
2202
|
-
})("display:flex;justify-content:", function (props) {
|
|
2207
|
+
})("list-style:none;margin:0;padding:0;display:flex;justify-content:", function (props) {
|
|
2203
2208
|
return buildButtonAlignment(props);
|
|
2204
2209
|
}, ";flex-direction:", function (props) {
|
|
2205
2210
|
return props.orientation === exports.ButtonGroupOrientation.vertical ? 'column' : 'row';
|
|
2206
2211
|
}, ";flex-wrap:wrap;", function (props) {
|
|
2207
|
-
return props.orientation === exports.ButtonGroupOrientation.vertical && /*#__PURE__*/react.css("align-items:", buildButtonAlignment(props), ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAyEQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2212
|
+
return props.orientation === exports.ButtonGroupOrientation.vertical && /*#__PURE__*/react.css("align-items:", buildButtonAlignment(props), ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2208
2213
|
}, " ", function (props) {
|
|
2209
|
-
return props.orientation === exports.ButtonGroupOrientation.horizontal && /*#__PURE__*/react.css("row-gap:", props.theme.spaceScale.spacing03, ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA8EQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2210
|
-
}, ">
|
|
2211
|
-
return props.orientation === exports.ButtonGroupOrientation.horizontal && _ref2;
|
|
2212
|
-
}, " ", function (props) {
|
|
2213
|
-
return props.orientation === exports.ButtonGroupOrientation.vertical && _ref$1;
|
|
2214
|
-
}, ";}>div{margin:", function (props) {
|
|
2214
|
+
return props.orientation === exports.ButtonGroupOrientation.horizontal && /*#__PURE__*/react.css("row-gap:", props.theme.spaceScale.spacing03, ";;label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAiFQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2215
|
+
}, ">li>div{margin:", function (props) {
|
|
2215
2216
|
return buildButtonMargin(props);
|
|
2216
2217
|
}, ";flex:", function (props) {
|
|
2217
2218
|
return props.alignment === exports.ButtonGroupAlignment.fill && props.orientation === exports.ButtonGroupOrientation.horizontal ? '1' : 'none';
|
|
2218
|
-
}, ";", function (props) {
|
|
2219
|
-
return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css("&:first-child:not(:only-child){button{border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}}&:nth-child(2){button{border-left:1px solid ", buildNoSpaceBorderColor(props), ";}}&:not(:first-child){button{border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}}&:not(:first-child)&:not(:last-child){button{border-right:0;}}&:last-child:not(:only-child){button{border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";}};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0HQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2220
|
-
}, ";button{width:", function (props) {
|
|
2219
|
+
}, ";div>button,button{width:", function (props) {
|
|
2221
2220
|
return props.alignment === exports.ButtonGroupAlignment.fill ? '100%' : '';
|
|
2222
|
-
}, ";&:nth-child(2){width:40px;}}}>button{margin:", function (props) {
|
|
2221
|
+
}, ";&:nth-child(2){width:40px;}}}>li>button{margin:", function (props) {
|
|
2223
2222
|
return buildButtonMargin(props);
|
|
2224
2223
|
}, ";flex:", function (props) {
|
|
2225
2224
|
return props.alignment === exports.ButtonGroupAlignment.fill && props.orientation === exports.ButtonGroupOrientation.horizontal ? '1' : 'none';
|
|
2226
2225
|
}, ";", function (props) {
|
|
2227
|
-
return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css("&:first-child:not(:only-child){border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}&:nth-child(2){border-left:1px solid ", buildNoSpaceBorderColor(props), ";}&:not(:first-child){border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}&:not(:first-child)&:not(:last-child){border-right:0;}&:last-child:not(:only-child){border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA2KQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2228
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkEqC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > button, > div {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child {\n          margin-left: 0;\n        }\n        &:last-child {\n          margin-right: 0;\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child {\n          margin-top: 0;\n        }\n        &:last-child {\n          margin-bottom: 0;\n        }\n      `}\n  }\n\n  > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      }\n    `};\n  }\n\n  > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          border-radius: ${props.theme.borderRadius} 0 0\n            ${props.theme.borderRadius};\n          border-right: 0;\n        }\n        &:nth-child(2) {\n          border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n        &:not(:first-child) {\n          border-radius: 0;\n          border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n        }\n        &:not(:first-child)&:not(:last-child) {\n          border-right: 0;\n        }\n        &:last-child:not(:only-child) {\n          border-radius: 0 ${props.theme.borderRadius}\n            ${props.theme.borderRadius} 0;\n          border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n        }\n      `}\n  }\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, children)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2226
|
+
return props.alignment === exports.ButtonGroupAlignment.fill && _ref3;
|
|
2227
|
+
}, ";}>li{", function (props) {
|
|
2228
|
+
return props.orientation === exports.ButtonGroupOrientation.horizontal && _ref2;
|
|
2229
|
+
}, " ", function (props) {
|
|
2230
|
+
return props.orientation === exports.ButtonGroupOrientation.vertical && _ref$1;
|
|
2231
|
+
}, " ", function (props) {
|
|
2232
|
+
return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css("&:first-child:not(:only-child){>div>div>button,>div>button,>button{border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}}&:nth-child(2){>div>div>button,>div>button,>button{border-left:1px solid ", buildNoSpaceBorderColor(props), ";}}&:not(:first-child){>div>div>button,>div>button,>button{border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}}&:not(:first-child)&:not(:last-child){>div>div>button,>div>button,>button{border-right:0;}}&:last-child:not(:only-child){>div>div>button,>div>button,>button{border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";}};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA0KQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2233
|
+
}, ";", function (props) {
|
|
2234
|
+
return props.noSpace && props.orientation === exports.ButtonGroupOrientation.horizontal && props.variant === exports.ButtonVariant.solid && props.alignment !== exports.ButtonGroupAlignment.apart && /*#__PURE__*/react.css(">div{&:first-child:not(:only-child){div>button,button{border-radius:", props.theme.borderRadius, " 0 0 ", props.theme.borderRadius, ";border-right:0;}}&:nth-child(2){div>button,button{border-left:1px solid ", buildNoSpaceBorderColor(props), ";}}&:not(:first-child){div>button,button{border-radius:0;border-right:", props.color === exports.ButtonColor.secondary || props.color === exports.ButtonColor.subtle ? '0' : "1px solid " + props.theme.colors.neutral100, ";}}&:not(:first-child)&:not(:last-child){div>button,button{border-right:0;}}&:last-child:not(:only-child){div>button,button{border-radius:0 ", props.theme.borderRadius, " ", props.theme.borderRadius, " 0;border-right:1px solid ", buildNoSpaceBorderColor(props), ";}}};label:StyledButtonGroup;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AA4NQ","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2235
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAkEqC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */"));
|
|
2236
|
+
var StyledButtonItem = /*#__PURE__*/_styled("li", {
|
|
2237
|
+
target: "encm85s0",
|
|
2238
|
+
label: "StyledButtonItem"
|
|
2239
|
+
})( {
|
|
2240
|
+
name: "dy2mza",
|
|
2241
|
+
styles: "list-style:none;margin:0;padding:0;display:contents/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.tsx"],"names":[],"mappings":"AAwQmC","file":"index.tsx","sourcesContent":["import * as React from 'react';\r\nimport { css } from '@emotion/react';\r\nimport styled from '@emotion/styled';\r\nimport { transparentize } from 'polished';\r\nimport { ThemeContext } from '../../theme/ThemeContext';\r\nimport { ButtonColor, ButtonVariant, } from '../Button';\r\nexport var ButtonGroupAlignment;\r\n(function (ButtonGroupAlignment) {\r\n    ButtonGroupAlignment[\"left\"] = \"left\";\r\n    ButtonGroupAlignment[\"center\"] = \"center\";\r\n    ButtonGroupAlignment[\"right\"] = \"right\";\r\n    ButtonGroupAlignment[\"apart\"] = \"apart\";\r\n    ButtonGroupAlignment[\"fill\"] = \"fill\";\r\n})(ButtonGroupAlignment || (ButtonGroupAlignment = {}));\r\nexport var ButtonGroupOrientation;\r\n(function (ButtonGroupOrientation) {\r\n    ButtonGroupOrientation[\"horizontal\"] = \"horizontal\";\r\n    ButtonGroupOrientation[\"vertical\"] = \"vertical\";\r\n})(ButtonGroupOrientation || (ButtonGroupOrientation = {}));\r\nexport const ButtonGroupContext = React.createContext({});\r\nfunction buildButtonMargin(props) {\r\n    if (props.noSpace) {\r\n        return '0';\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return `0 ${props.theme.spaceScale.spacing02}`;\r\n    }\r\n    if (props.orientation === ButtonGroupOrientation.vertical) {\r\n        return `0 0 ${props.theme.spaceScale.spacing03}`;\r\n    }\r\n    return `0 ${props.theme.spaceScale.spacing02}`;\r\n}\r\nfunction buildButtonAlignment(props) {\r\n    if (props.alignment === ButtonGroupAlignment.right) {\r\n        return 'end';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.center) {\r\n        return 'center';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.apart &&\r\n        props.orientation === ButtonGroupOrientation.horizontal) {\r\n        return 'space-between';\r\n    }\r\n    if (props.alignment === ButtonGroupAlignment.fill) {\r\n        return 'stretch';\r\n    }\r\n    return 'start';\r\n}\r\nfunction buildNoSpaceBorderColor(props) {\r\n    if (props.isInverse) {\r\n        if (props.color === ButtonColor.secondary) {\r\n            return props.theme.colors.tertiary;\r\n        }\r\n        if (props.color === ButtonColor.subtle) {\r\n            return transparentize(0.8, props.theme.colors.neutral300);\r\n        }\r\n        return props.theme.colors.neutral100;\r\n    }\r\n    if (props.color === ButtonColor.secondary) {\r\n        return props.theme.colors.primary300;\r\n    }\r\n    if (props.color === ButtonColor.subtle) {\r\n        return props.theme.colors.neutral300;\r\n    }\r\n    return props.theme.colors.neutral100;\r\n}\r\nconst StyledButtonGroup = styled.div `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: flex;\n  justify-content: ${props => buildButtonAlignment(props)};\n  flex-direction: ${props => props.orientation === ButtonGroupOrientation.vertical ? 'column' : 'row'};\n  flex-wrap: wrap;\n\n  ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n      align-items: ${buildButtonAlignment(props)};\n    `}\n\n  ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n      row-gap: ${props.theme.spaceScale.spacing03};\n    `}\n\n  > li > div {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n    div > button,\n    button {\n      // Split buttons\n      &:nth-child(2) {\n        width: 40px;\n      }\n      width: ${props => props.alignment === ButtonGroupAlignment.fill ? '100%' : ''};\n    }\n  }\n\n  > li > button {\n    margin: ${props => buildButtonMargin(props)};\n    flex: ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    props.orientation === ButtonGroupOrientation.horizontal\r\n    ? '1'\r\n    : 'none'};\n\n    // Only apply width 100% to buttons that are NOT icon-only buttons\n    ${props => props.alignment === ButtonGroupAlignment.fill &&\r\n    css `\n        &:not([aria-label]):not([title]) {\n          width: 100%;\n        }\n        &[aria-label]:empty,\n        &[title]:empty {\n          width: auto;\n          flex: none;\n        }\n        // Check if button has only icon content (no text)\n        &:has(svg):not(:has(:not(svg))) {\n          width: auto;\n          flex: none;\n        }\n      `}\n  }\n\n  > li {\n    ${props => props.orientation === ButtonGroupOrientation.horizontal &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-left: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-right: 0;\n          }\n        }\n      `}\n\n    ${props => props.orientation === ButtonGroupOrientation.vertical &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-top: 0;\n          }\n        }\n\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            margin-bottom: 0;\n          }\n        }\n      `}\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        &:first-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: ${props.theme.borderRadius} 0 0\n              ${props.theme.borderRadius};\n            border-right: 0;\n          }\n        }\n        &:nth-child(2) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n        &:not(:first-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0;\n            border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n          }\n        }\n        &:not(:first-child)&:not(:last-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-right: 0;\n          }\n        }\n        &:last-child:not(:only-child) {\n          > div > div > button,\n          > div > button,\n          > button {\n            border-radius: 0 ${props.theme.borderRadius}\n              ${props.theme.borderRadius} 0;\n            border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n          }\n        }\n      `};\n\n    ${props => props.noSpace &&\r\n    props.orientation === ButtonGroupOrientation.horizontal &&\r\n    props.variant === ButtonVariant.solid &&\r\n    props.alignment !== ButtonGroupAlignment.apart &&\r\n    css `\n        > div {\n          &:first-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: ${props.theme.borderRadius} 0 0\n                ${props.theme.borderRadius};\n              border-right: 0;\n            }\n          }\n          &:nth-child(2) {\n            div > button,\n            button {\n              border-left: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n          &:not(:first-child) {\n            div > button,\n            button {\n              border-radius: 0;\n              border-right: ${props.color === ButtonColor.secondary ||\r\n        props.color === ButtonColor.subtle\r\n        ? '0'\r\n        : `1px solid ${props.theme.colors.neutral100}`};\n            }\n          }\n          &:not(:first-child)&:not(:last-child) {\n            div > button,\n            button {\n              border-right: 0;\n            }\n          }\n          &:last-child:not(:only-child) {\n            div > button,\n            button {\n              border-radius: 0 ${props.theme.borderRadius}\n                ${props.theme.borderRadius} 0;\n              border-right: 1px solid ${buildNoSpaceBorderColor(props)};\n            }\n          }\n        }\n      `};\n  }\n`;\r\nconst StyledButtonItem = styled.li `\n  list-style: none;\n  margin: 0;\n  padding: 0;\n  display: contents;\n`;\r\nexport const ButtonGroup = React.forwardRef((props, ref) => {\r\n    const { alignment, children, color, isInverse, orientation, noSpace, size, testId, textTransform, variant, ...rest } = props;\r\n    const context = { variant, color, size, textTransform, isInverse };\r\n    const theme = React.useContext(ThemeContext);\r\n    const wrappedChildren = React.Children.map(children, child => (React.createElement(StyledButtonItem, null, child)));\r\n    return (React.createElement(StyledButtonGroup, Object.assign({ alignment: alignment || ButtonGroupAlignment.left, color: color || ButtonColor.primary, isInverse: isInverse, orientation: orientation || ButtonGroupOrientation.horizontal, noSpace: noSpace, variant: variant || ButtonVariant.solid, theme: theme, ref: ref, \"data-testid\": testId }, rest, { as: 'ul', role: \"list\" }),\r\n        React.createElement(ButtonGroupContext.Provider, { value: context }, wrappedChildren)));\r\n});\r\n//# sourceMappingURL=index.js.map"]} */",
|
|
2242
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
|
|
2243
|
+
});
|
|
2229
2244
|
var ButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
2230
2245
|
var alignment = props.alignment,
|
|
2231
2246
|
children = props.children,
|
|
@@ -2246,6 +2261,9 @@ var ButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
2246
2261
|
isInverse: isInverse
|
|
2247
2262
|
};
|
|
2248
2263
|
var theme = React.useContext(ThemeContext);
|
|
2264
|
+
var wrappedChildren = React.Children.map(children, function (child) {
|
|
2265
|
+
return /*#__PURE__*/React.createElement(StyledButtonItem, null, child);
|
|
2266
|
+
});
|
|
2249
2267
|
return /*#__PURE__*/React.createElement(StyledButtonGroup, Object.assign({
|
|
2250
2268
|
alignment: alignment || exports.ButtonGroupAlignment.left,
|
|
2251
2269
|
color: color || exports.ButtonColor.primary,
|
|
@@ -2256,9 +2274,12 @@ var ButtonGroup = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
|
|
2256
2274
|
theme: theme,
|
|
2257
2275
|
ref: ref,
|
|
2258
2276
|
"data-testid": testId
|
|
2259
|
-
}, rest
|
|
2277
|
+
}, rest, {
|
|
2278
|
+
as: 'ul',
|
|
2279
|
+
role: "list"
|
|
2280
|
+
}), /*#__PURE__*/React.createElement(ButtonGroupContext.Provider, {
|
|
2260
2281
|
value: context
|
|
2261
|
-
},
|
|
2282
|
+
}, wrappedChildren));
|
|
2262
2283
|
});
|
|
2263
2284
|
|
|
2264
2285
|
var DEFAULT_STYLE_PROPS$1 = {
|
|
@@ -9626,7 +9647,7 @@ var Container$2 = /*#__PURE__*/_styled("div", {
|
|
|
9626
9647
|
label: "Container"
|
|
9627
9648
|
})( {
|
|
9628
9649
|
name: "11ffxfj",
|
|
9629
|
-
styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Dropdown.tsx"],"names":[],"mappings":"AAoB6B","file":"Dropdown.tsx","sourcesContent":["import * as React from 'react';\r\nimport { useState } from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, offset, useFloating, } from '@floating-ui/react-dom';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var DropdownDropDirection;\r\n(function (DropdownDropDirection) {\r\n    DropdownDropDirection[\"down\"] = \"down\";\r\n    DropdownDropDirection[\"left\"] = \"left\";\r\n    DropdownDropDirection[\"right\"] = \"right\";\r\n    DropdownDropDirection[\"up\"] = \"up\";\r\n})(DropdownDropDirection || (DropdownDropDirection = {}));\r\nexport var DropdownAlignment;\r\n(function (DropdownAlignment) {\r\n    DropdownAlignment[\"start\"] = \"start\";\r\n    DropdownAlignment[\"end\"] = \"end\";\r\n})(DropdownAlignment || (DropdownAlignment = {}));\r\nconst Container = styled.div `\n  display: inline-block;\n  position: relative;\n`;\r\nexport const DropdownContext = React.createContext({\r\n    isOpen: false,\r\n    registerDropdownMenuItem: (elements, element) => { },\r\n    setIsOpen: () => false,\r\n});\r\nexport const useDropdownContext = () => React.useContext(DropdownContext);\r\nexport const Dropdown = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { activeIndex, alignment, children, dropDirection, maxHeight, onClose, onOpen, testId, width, ...other } = resolvedProps;\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const [activeItemIndex, setActiveItemIndex] = React.useState(activeIndex || -1);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef(null);\r\n    const menuRef = React.useRef([]);\r\n    const dropdownButtonId = React.useRef('');\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const [itemRefArray, registerDropdownMenuItem] = useDescendants();\r\n    React.useEffect(() => {\r\n        if (activeIndex >= 0) {\r\n            setActiveItemIndex(activeIndex);\r\n        }\r\n    }, [activeIndex]);\r\n    function openDropdown() {\r\n        const [filteredItems] = getFilteredItem();\r\n        setIsOpen(true);\r\n        if (filteredItems.length > 0) {\r\n            setTimeout(() => {\r\n                filteredItems[0]?.current?.focus();\r\n            }, 0);\r\n        }\r\n        else {\r\n            setTimeout(() => {\r\n                menuRef.current.focus();\r\n            }, 0);\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closeDropdown(event) {\r\n        setIsOpen(false);\r\n        toggleRef.current?.focus();\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function getFilteredItem() {\r\n        const filteredItems = itemRefArray.current.filter(itemRef => itemRef.current);\r\n        const filteredItemIndex = filteredItems\r\n            .map(filteredItem => filteredItem.current)\r\n            .indexOf(document.activeElement);\r\n        return [filteredItems, filteredItemIndex];\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            closeDropdown(event);\r\n        }\r\n        if (event.key === 'ArrowDown') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 ||\r\n                filteredItemIndex === filteredItems.length - 1) {\r\n                filteredItems[0].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex + 1].current.focus();\r\n            }\r\n        }\r\n        if (event.key === 'ArrowUp') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 || filteredItemIndex === 0) {\r\n                filteredItems[filteredItems.length - 1].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex - 1].current.focus();\r\n            }\r\n        }\r\n    }\r\n    function handleDropdownBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closeDropdown(event);\r\n        }\r\n    }\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = typeof width === 'number' ? `${width}px` : width;\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const [placement, setPlacement] = useState('bottom-start');\r\n    const changePlacement = (dropDirection = DropdownDropDirection.down, alignment = DropdownAlignment.start) => {\r\n        const placementMap = new Map([\r\n            ['up-start', 'top-start'],\r\n            ['up-end', 'top-end'],\r\n            ['right-start', 'right-start'],\r\n            ['right-end', 'right-end'],\r\n            ['down-end', 'bottom-end'],\r\n            ['left-start', 'left-start'],\r\n            ['left-end', 'left-end'],\r\n        ]);\r\n        // dropDirection & alignment are deprecated.\r\n        // this fallback can be removed when the props are deleted.\r\n        const contentPosition = `${dropDirection}-${alignment}`;\r\n        setPlacement(placementMap.get(contentPosition) ?? 'bottom-start');\r\n    };\r\n    const { refs, floatingStyles, elements, update } = useFloating({\r\n        middleware: [flip(), offset(2)],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        changePlacement(dropDirection, alignment);\r\n    }, [dropDirection, alignment]);\r\n    // Need cleanup state to avoid memory leaks\r\n    React.useEffect(() => {\r\n        const referenceDropdownButton = elements.reference;\r\n        const floatingDropdownContent = elements.floating;\r\n        if (isOpen && referenceDropdownButton && floatingDropdownContent) {\r\n            return autoUpdate(referenceDropdownButton, floatingDropdownContent, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const contextValue = React.useMemo(() => ({\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        isFixedWidth: !!width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeight: maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        setReference: refs.setReference,\r\n        setFloating: refs.setFloating,\r\n        toggleRef,\r\n        width: widthString,\r\n    }), [\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        refs.setReference,\r\n        refs.setFloating,\r\n        toggleRef,\r\n        widthString,\r\n    ]);\r\n    return (React.createElement(DropdownContext.Provider, { value: contextValue },\r\n        React.createElement(Container, Object.assign({}, other, { ref: ref, \"data-testid\": testId, onKeyDown: isOpen ? handleKeyDown : null, onBlur: handleDropdownBlur }), children)));\r\n});\r\n//# sourceMappingURL=Dropdown.js.map"]} */",
|
|
9650
|
+
styles: "display:inline-block;position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Dropdown.tsx"],"names":[],"mappings":"AAoB6B","file":"Dropdown.tsx","sourcesContent":["import * as React from 'react';\r\nimport { useState } from 'react';\r\nimport styled from '@emotion/styled';\r\nimport { autoUpdate, flip, offset, useFloating, } from '@floating-ui/react-dom';\r\nimport { useDescendants } from '../../hooks/useDescendants';\r\nimport { useIsInverse } from '../../inverse';\r\nimport { resolveProps, useForkedRef, useGenerateId } from '../../utils';\r\nimport { ButtonGroupContext } from '../ButtonGroup';\r\nexport var DropdownDropDirection;\r\n(function (DropdownDropDirection) {\r\n    DropdownDropDirection[\"down\"] = \"down\";\r\n    DropdownDropDirection[\"left\"] = \"left\";\r\n    DropdownDropDirection[\"right\"] = \"right\";\r\n    DropdownDropDirection[\"up\"] = \"up\";\r\n})(DropdownDropDirection || (DropdownDropDirection = {}));\r\nexport var DropdownAlignment;\r\n(function (DropdownAlignment) {\r\n    DropdownAlignment[\"start\"] = \"start\";\r\n    DropdownAlignment[\"end\"] = \"end\";\r\n})(DropdownAlignment || (DropdownAlignment = {}));\r\nconst Container = styled.div `\n  display: inline-block;\n  position: relative;\n`;\r\nexport const DropdownContext = React.createContext({\r\n    isOpen: false,\r\n    registerDropdownMenuItem: (elements, element) => { },\r\n    setIsOpen: () => false,\r\n});\r\nexport const useDropdownContext = () => React.useContext(DropdownContext);\r\nexport const Dropdown = React.forwardRef((props, forwardedRef) => {\r\n    const contextProps = React.useContext(ButtonGroupContext);\r\n    const resolvedProps = resolveProps(contextProps, props);\r\n    const { activeIndex, alignment, children, dropDirection, maxHeight, onClose, onOpen, testId, width, ...other } = resolvedProps;\r\n    const [isOpen, setIsOpen] = React.useState(false);\r\n    const [activeItemIndex, setActiveItemIndex] = React.useState(activeIndex || -1);\r\n    const ownRef = React.useRef();\r\n    const toggleRef = React.useRef(null);\r\n    const menuRef = React.useRef([]);\r\n    const dropdownButtonId = React.useRef('');\r\n    const ref = useForkedRef(forwardedRef, ownRef);\r\n    const [itemRefArray, registerDropdownMenuItem] = useDescendants();\r\n    React.useEffect(() => {\r\n        if (activeIndex >= 0) {\r\n            setActiveItemIndex(activeIndex);\r\n        }\r\n    }, [activeIndex]);\r\n    function openDropdown() {\r\n        const [filteredItems] = getFilteredItem();\r\n        setIsOpen(true);\r\n        if (filteredItems.length > 0) {\r\n            setTimeout(() => {\r\n                filteredItems[0]?.current?.focus();\r\n            }, 0);\r\n        }\r\n        else {\r\n            setTimeout(() => {\r\n                menuRef.current.focus();\r\n            }, 0);\r\n        }\r\n        onOpen && typeof onOpen === 'function' && onOpen();\r\n    }\r\n    function closeDropdown(event) {\r\n        setIsOpen(false);\r\n        toggleRef.current?.focus();\r\n        onClose && typeof onClose === 'function' && onClose(event);\r\n    }\r\n    function getFilteredItem() {\r\n        const filteredItems = itemRefArray.current.filter(itemRef => itemRef.current);\r\n        const filteredItemIndex = filteredItems\r\n            .map(filteredItem => filteredItem.current)\r\n            .indexOf(document.activeElement);\r\n        return [filteredItems, filteredItemIndex];\r\n    }\r\n    function handleKeyDown(event) {\r\n        if (event.key === 'Escape') {\r\n            event.nativeEvent.stopImmediatePropagation();\r\n            closeDropdown(event);\r\n        }\r\n        if (event.key === 'ArrowDown') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 ||\r\n                filteredItemIndex === filteredItems.length - 1) {\r\n                filteredItems[0].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex + 1].current.focus();\r\n            }\r\n        }\r\n        if (event.key === 'ArrowUp') {\r\n            const [filteredItems, filteredItemIndex] = getFilteredItem();\r\n            if (filteredItems.length === 0) {\r\n                return;\r\n            }\r\n            event.preventDefault();\r\n            if (filteredItemIndex === -1 || filteredItemIndex === 0) {\r\n                filteredItems[filteredItems.length - 1].current.focus();\r\n            }\r\n            else {\r\n                filteredItems[filteredItemIndex - 1].current.focus();\r\n            }\r\n        }\r\n    }\r\n    function handleDropdownBlur(event) {\r\n        const { currentTarget, relatedTarget } = event;\r\n        const isInMenu = relatedTarget && currentTarget.contains(relatedTarget);\r\n        if (!isInMenu && isOpen) {\r\n            closeDropdown(event);\r\n        }\r\n    }\r\n    const maxHeightString = typeof maxHeight === 'number' ? `${maxHeight}px` : maxHeight;\r\n    const widthString = typeof width === 'number' ? `${width}px` : width;\r\n    const isInverse = useIsInverse(resolvedProps.isInverse);\r\n    const [placement, setPlacement] = useState('bottom-start');\r\n    dropdownButtonId.current = useGenerateId();\r\n    const changePlacement = (dropDirection = DropdownDropDirection.down, alignment = DropdownAlignment.start) => {\r\n        const placementMap = new Map([\r\n            ['up-start', 'top-start'],\r\n            ['up-end', 'top-end'],\r\n            ['right-start', 'right-start'],\r\n            ['right-end', 'right-end'],\r\n            ['down-end', 'bottom-end'],\r\n            ['left-start', 'left-start'],\r\n            ['left-end', 'left-end'],\r\n        ]);\r\n        // dropDirection & alignment are deprecated.\r\n        // this fallback can be removed when the props are deleted.\r\n        const contentPosition = `${dropDirection}-${alignment}`;\r\n        setPlacement(placementMap.get(contentPosition) ?? 'bottom-start');\r\n    };\r\n    const { refs, floatingStyles, elements, update } = useFloating({\r\n        middleware: [flip(), offset(2)],\r\n        placement: placement,\r\n        whileElementsMounted: autoUpdate,\r\n    });\r\n    React.useEffect(() => {\r\n        changePlacement(dropDirection, alignment);\r\n    }, [dropDirection, alignment]);\r\n    // Need cleanup state to avoid memory leaks\r\n    React.useEffect(() => {\r\n        const referenceDropdownButton = elements.reference;\r\n        const floatingDropdownContent = elements.floating;\r\n        if (isOpen && referenceDropdownButton && floatingDropdownContent) {\r\n            return autoUpdate(referenceDropdownButton, floatingDropdownContent, update);\r\n        }\r\n    }, [isOpen, elements, update]);\r\n    const contextValue = React.useMemo(() => ({\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        isFixedWidth: !!width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeight: maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        setReference: refs.setReference,\r\n        setFloating: refs.setFloating,\r\n        toggleRef,\r\n        width: widthString,\r\n    }), [\r\n        activeItemIndex,\r\n        alignment,\r\n        closeDropdown,\r\n        dropdownButtonId,\r\n        dropDirection,\r\n        floatingStyles,\r\n        handleDropdownBlur,\r\n        itemRefArray,\r\n        width,\r\n        isOpen,\r\n        isInverse,\r\n        maxHeightString,\r\n        menuRef,\r\n        openDropdown,\r\n        registerDropdownMenuItem,\r\n        setActiveItemIndex,\r\n        setIsOpen,\r\n        refs.setReference,\r\n        refs.setFloating,\r\n        toggleRef,\r\n        widthString,\r\n    ]);\r\n    return (React.createElement(DropdownContext.Provider, { value: contextValue },\r\n        React.createElement(Container, Object.assign({}, other, { ref: ref, \"data-testid\": testId, onKeyDown: isOpen ? handleKeyDown : null, onBlur: handleDropdownBlur }), children)));\r\n});\r\n//# sourceMappingURL=Dropdown.js.map"]} */",
|
|
9630
9651
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
9631
9652
|
});
|
|
9632
9653
|
var DropdownContext = /*#__PURE__*/React.createContext({
|
|
@@ -9747,6 +9768,7 @@ var Dropdown = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
|
9747
9768
|
var _useState = React.useState('bottom-start'),
|
|
9748
9769
|
placement = _useState[0],
|
|
9749
9770
|
setPlacement = _useState[1];
|
|
9771
|
+
dropdownButtonId.current = useGenerateId();
|
|
9750
9772
|
var changePlacement = function changePlacement(dropDirection, alignment) {
|
|
9751
9773
|
var _placementMap$get;
|
|
9752
9774
|
if (dropDirection === void 0) {
|
|
@@ -9816,7 +9838,7 @@ var Dropdown = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
|
9816
9838
|
}), children));
|
|
9817
9839
|
});
|
|
9818
9840
|
|
|
9819
|
-
var _excluded$R = ["icon", "iconPosition", "leadingIcon"];
|
|
9841
|
+
var _excluded$R = ["icon", "iconPosition", "leadingIcon", "id"];
|
|
9820
9842
|
function instanceOfIconOnlyDropdownButton(object) {
|
|
9821
9843
|
return 'icon' in object && !('children' in object);
|
|
9822
9844
|
}
|
|
@@ -9834,14 +9856,13 @@ var StyledIconButton = /*#__PURE__*/_styled(IconButton, {
|
|
|
9834
9856
|
target: "ewl0bx30",
|
|
9835
9857
|
label: "StyledIconButton"
|
|
9836
9858
|
})(function (props) {
|
|
9837
|
-
return props.iconPosition === exports.ButtonIconPosition.right && props.children && /*#__PURE__*/react.css("padding-right:", getButtonPadding(props.theme, props.size), ";;label:StyledIconButton;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9859
|
+
return props.iconPosition === exports.ButtonIconPosition.right && props.children && /*#__PURE__*/react.css("padding-right:", getButtonPadding(props.theme, props.size), ";;label:StyledIconButton;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duQnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QlEiLCJmaWxlIjoiRHJvcGRvd25CdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgQXJyb3dEcm9wRG93bkljb24sIEFycm93RHJvcFVwSWNvbiwgQXJyb3dMZWZ0SWNvbiwgQXJyb3dSaWdodEljb24sIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBCdXR0b25JY29uUG9zaXRpb24sIEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgRHJvcGRvd25Db250ZXh0LCBEcm9wZG93bkRyb3BEaXJlY3Rpb24gfSBmcm9tICcuL0Ryb3Bkb3duJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5mdW5jdGlvbiBpbnN0YW5jZU9mSWNvbk9ubHlEcm9wZG93bkJ1dHRvbihvYmplY3QpIHtcclxuICAgIHJldHVybiAnaWNvbicgaW4gb2JqZWN0ICYmICEoJ2NoaWxkcmVuJyBpbiBvYmplY3QpO1xyXG59XHJcbmZ1bmN0aW9uIGdldEJ1dHRvblBhZGRpbmcodGhlbWUsIHNpemUpIHtcclxuICAgIHN3aXRjaCAoc2l6ZSkge1xyXG4gICAgICAgIGNhc2UgJ3NtYWxsJzpcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyO1xyXG4gICAgICAgIGNhc2UgJ2xhcmdlJzpcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1O1xyXG4gICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgIHJldHVybiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMztcclxuICAgIH1cclxufVxyXG5jb25zdCBTdHlsZWRJY29uQnV0dG9uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtwcm9wcyA9PiBwcm9wcy5pY29uUG9zaXRpb24gPT09IEJ1dHRvbkljb25Qb3NpdGlvbi5yaWdodCAmJlxyXG4gICAgcHJvcHMuY2hpbGRyZW4gJiZcclxuICAgIGNzcyBgXG4gICAgICBwYWRkaW5nLXJpZ2h0OiAke2dldEJ1dHRvblBhZGRpbmcocHJvcHMudGhlbWUsIHByb3BzLnNpemUpfTtcbiAgICBgfVxuICAke3Byb3BzID0+IHByb3BzLmljb25Qb3NpdGlvbiA9PT0gQnV0dG9uSWNvblBvc2l0aW9uLmxlZnQgJiZcclxuICAgIHByb3BzLmNoaWxkcmVuICYmXHJcbiAgICBjc3MgYFxuICAgICAgcGFkZGluZy1sZWZ0OiAke2dldEJ1dHRvblBhZGRpbmcocHJvcHMudGhlbWUsIHByb3BzLnNpemUpfTtcbiAgICBgfVxuYDtcclxuZXhwb3J0IGNvbnN0IERyb3Bkb3duQnV0dG9uID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIGZvcndhcmRlZFJlZikgPT4ge1xyXG4gICAgY29uc3QgY29udGV4dCA9IFJlYWN0LnVzZUNvbnRleHQoRHJvcGRvd25Db250ZXh0KTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGNvbnRleHQudG9nZ2xlUmVmLCBmb3J3YXJkZWRSZWYpO1xyXG4gICAgZnVuY3Rpb24gZ2V0QnV0dG9uSWNvbihkcm9wRGlyZWN0aW9uKSB7XHJcbiAgICAgICAgc3dpdGNoIChkcm9wRGlyZWN0aW9uKSB7XHJcbiAgICAgICAgICAgIGNhc2UgRHJvcGRvd25Ecm9wRGlyZWN0aW9uLmxlZnQ6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChBcnJvd0xlZnRJY29uLCB7IHRlc3RJZDogXCJjYXJldExlZnRcIiwgXCJhcmlhLWhpZGRlblwiOiBcInRydWVcIiB9KTtcclxuICAgICAgICAgICAgY2FzZSBEcm9wZG93bkRyb3BEaXJlY3Rpb24ucmlnaHQ6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChBcnJvd1JpZ2h0SWNvbiwgeyB0ZXN0SWQ6IFwiY2FyZXRSaWdodFwiLCBcImFyaWEtaGlkZGVuXCI6IFwidHJ1ZVwiIH0pO1xyXG4gICAgICAgICAgICBjYXNlIERyb3Bkb3duRHJvcERpcmVjdGlvbi51cDpcclxuICAgICAgICAgICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KEFycm93RHJvcFVwSWNvbiwgeyB0ZXN0SWQ6IFwiY2FyZXRVcFwiLCBcImFyaWEtaGlkZGVuXCI6IFwidHJ1ZVwiIH0pO1xyXG4gICAgICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQXJyb3dEcm9wRG93bkljb24sIHsgdGVzdElkOiBcImNhcmV0RG93blwiLCBcImFyaWEtaGlkZGVuXCI6IFwidHJ1ZVwiIH0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIGNvbnN0IGJ1dHRvbkljb24gPSBnZXRCdXR0b25JY29uKGNvbnRleHQuZHJvcERpcmVjdGlvbik7XHJcbiAgICBsZXQgY2hpbGRyZW47XHJcbiAgICBjb25zdCB7IGljb24gPSBidXR0b25JY29uLCBpY29uUG9zaXRpb24sIGxlYWRpbmdJY29uLCBpZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgaWYgKCFpbnN0YW5jZU9mSWNvbk9ubHlEcm9wZG93bkJ1dHRvbihwcm9wcykpIHtcclxuICAgICAgICBjaGlsZHJlbiA9IHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgZnVuY3Rpb24gaGFuZGxlQ2xpY2soZXZlbnQpIHtcclxuICAgICAgICBpZiAoY29udGV4dC5pc09wZW4pIHtcclxuICAgICAgICAgICAgY29udGV4dC5jbG9zZURyb3Bkb3duKGV2ZW50KTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIGNvbnRleHQub3BlbkRyb3Bkb3duKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgbGV0IGljb25Qb3NpdGlvblRvVXNlO1xyXG4gICAgaWYgKHByb3BzLmljb24pIHtcclxuICAgICAgICBpY29uUG9zaXRpb25Ub1VzZSA9IGljb25Qb3NpdGlvbiA/PyBCdXR0b25JY29uUG9zaXRpb24ubGVmdDtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIGljb25Qb3NpdGlvblRvVXNlID1cclxuICAgICAgICAgICAgY29udGV4dC5kcm9wRGlyZWN0aW9uID09PSBEcm9wZG93bkRyb3BEaXJlY3Rpb24ubGVmdFxyXG4gICAgICAgICAgICAgICAgPyBCdXR0b25JY29uUG9zaXRpb24ubGVmdFxyXG4gICAgICAgICAgICAgICAgOiBCdXR0b25JY29uUG9zaXRpb24ucmlnaHQ7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyByZWY6IGNvbnRleHQuc2V0UmVmZXJlbmNlIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRJY29uQnV0dG9uLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtY29udHJvbHNcIjogKGlkID8/IGNvbnRleHQuZHJvcGRvd25CdXR0b25JZC5jdXJyZW50KSArICdfZHJvcGRvd25NZW51SWQnLCBcImFyaWEtZXhwYW5kZWRcIjogY29udGV4dC5pc09wZW4sIFwiYXJpYS1oYXNwb3B1cFwiOiBcInRydWVcIiwgaWNvbjogaWNvbiwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb25Ub1VzZSwgaWQ6IGlkID8/IGNvbnRleHQuZHJvcGRvd25CdXR0b25JZC5jdXJyZW50LCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlLCBsZWFkaW5nSWNvbjogbGVhZGluZ0ljb24sIG9uQ2xpY2s6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pLCBjaGlsZHJlbikpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPURyb3Bkb3duQnV0dG9uLmpzLm1hcCJdfQ== */"));
|
|
9838
9860
|
}, " ", function (props) {
|
|
9839
|
-
return props.iconPosition === exports.ButtonIconPosition.left && props.children && /*#__PURE__*/react.css("padding-left:", getButtonPadding(props.theme, props.size), ";;label:StyledIconButton;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9840
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9861
|
+
return props.iconPosition === exports.ButtonIconPosition.left && props.children && /*#__PURE__*/react.css("padding-left:", getButtonPadding(props.theme, props.size), ";;label:StyledIconButton;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duQnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QlEiLCJmaWxlIjoiRHJvcGRvd25CdXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcclxuaW1wb3J0IHsgQXJyb3dEcm9wRG93bkljb24sIEFycm93RHJvcFVwSWNvbiwgQXJyb3dMZWZ0SWNvbiwgQXJyb3dSaWdodEljb24sIH0gZnJvbSAncmVhY3QtbWFnbWEtaWNvbnMnO1xyXG5pbXBvcnQgeyBCdXR0b25JY29uUG9zaXRpb24sIEljb25CdXR0b24gfSBmcm9tICcuLi9JY29uQnV0dG9uJztcclxuaW1wb3J0IHsgRHJvcGRvd25Db250ZXh0LCBEcm9wZG93bkRyb3BEaXJlY3Rpb24gfSBmcm9tICcuL0Ryb3Bkb3duJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5mdW5jdGlvbiBpbnN0YW5jZU9mSWNvbk9ubHlEcm9wZG93bkJ1dHRvbihvYmplY3QpIHtcclxuICAgIHJldHVybiAnaWNvbicgaW4gb2JqZWN0ICYmICEoJ2NoaWxkcmVuJyBpbiBvYmplY3QpO1xyXG59XHJcbmZ1bmN0aW9uIGdldEJ1dHRvblBhZGRpbmcodGhlbWUsIHNpemUpIHtcclxuICAgIHN3aXRjaCAoc2l6ZSkge1xyXG4gICAgICAgIGNhc2UgJ3NtYWxsJzpcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzAyO1xyXG4gICAgICAgIGNhc2UgJ2xhcmdlJzpcclxuICAgICAgICAgICAgcmV0dXJuIHRoZW1lLnNwYWNlU2NhbGUuc3BhY2luZzA1O1xyXG4gICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgIHJldHVybiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMztcclxuICAgIH1cclxufVxyXG5jb25zdCBTdHlsZWRJY29uQnV0dG9uID0gc3R5bGVkKEljb25CdXR0b24pIGBcbiAgJHtwcm9wcyA9PiBwcm9wcy5pY29uUG9zaXRpb24gPT09IEJ1dHRvbkljb25Qb3NpdGlvbi5yaWdodCAmJlxyXG4gICAgcHJvcHMuY2hpbGRyZW4gJiZcclxuICAgIGNzcyBgXG4gICAgICBwYWRkaW5nLXJpZ2h0OiAke2dldEJ1dHRvblBhZGRpbmcocHJvcHMudGhlbWUsIHByb3BzLnNpemUpfTtcbiAgICBgfVxuICAke3Byb3BzID0+IHByb3BzLmljb25Qb3NpdGlvbiA9PT0gQnV0dG9uSWNvblBvc2l0aW9uLmxlZnQgJiZcclxuICAgIHByb3BzLmNoaWxkcmVuICYmXHJcbiAgICBjc3MgYFxuICAgICAgcGFkZGluZy1sZWZ0OiAke2dldEJ1dHRvblBhZGRpbmcocHJvcHMudGhlbWUsIHByb3BzLnNpemUpfTtcbiAgICBgfVxuYDtcclxuZXhwb3J0IGNvbnN0IERyb3Bkb3duQnV0dG9uID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIGZvcndhcmRlZFJlZikgPT4ge1xyXG4gICAgY29uc3QgY29udGV4dCA9IFJlYWN0LnVzZUNvbnRleHQoRHJvcGRvd25Db250ZXh0KTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGNvbnRleHQudG9nZ2xlUmVmLCBmb3J3YXJkZWRSZWYpO1xyXG4gICAgZnVuY3Rpb24gZ2V0QnV0dG9uSWNvbihkcm9wRGlyZWN0aW9uKSB7XHJcbiAgICAgICAgc3dpdGNoIChkcm9wRGlyZWN0aW9uKSB7XHJcbiAgICAgICAgICAgIGNhc2UgRHJvcGRvd25Ecm9wRGlyZWN0aW9uLmxlZnQ6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChBcnJvd0xlZnRJY29uLCB7IHRlc3RJZDogXCJjYXJldExlZnRcIiwgXCJhcmlhLWhpZGRlblwiOiBcInRydWVcIiB9KTtcclxuICAgICAgICAgICAgY2FzZSBEcm9wZG93bkRyb3BEaXJlY3Rpb24ucmlnaHQ6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChBcnJvd1JpZ2h0SWNvbiwgeyB0ZXN0SWQ6IFwiY2FyZXRSaWdodFwiLCBcImFyaWEtaGlkZGVuXCI6IFwidHJ1ZVwiIH0pO1xyXG4gICAgICAgICAgICBjYXNlIERyb3Bkb3duRHJvcERpcmVjdGlvbi51cDpcclxuICAgICAgICAgICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KEFycm93RHJvcFVwSWNvbiwgeyB0ZXN0SWQ6IFwiY2FyZXRVcFwiLCBcImFyaWEtaGlkZGVuXCI6IFwidHJ1ZVwiIH0pO1xyXG4gICAgICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQXJyb3dEcm9wRG93bkljb24sIHsgdGVzdElkOiBcImNhcmV0RG93blwiLCBcImFyaWEtaGlkZGVuXCI6IFwidHJ1ZVwiIH0pO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIGNvbnN0IGJ1dHRvbkljb24gPSBnZXRCdXR0b25JY29uKGNvbnRleHQuZHJvcERpcmVjdGlvbik7XHJcbiAgICBsZXQgY2hpbGRyZW47XHJcbiAgICBjb25zdCB7IGljb24gPSBidXR0b25JY29uLCBpY29uUG9zaXRpb24sIGxlYWRpbmdJY29uLCBpZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgaWYgKCFpbnN0YW5jZU9mSWNvbk9ubHlEcm9wZG93bkJ1dHRvbihwcm9wcykpIHtcclxuICAgICAgICBjaGlsZHJlbiA9IHByb3BzLmNoaWxkcmVuO1xyXG4gICAgfVxyXG4gICAgZnVuY3Rpb24gaGFuZGxlQ2xpY2soZXZlbnQpIHtcclxuICAgICAgICBpZiAoY29udGV4dC5pc09wZW4pIHtcclxuICAgICAgICAgICAgY29udGV4dC5jbG9zZURyb3Bkb3duKGV2ZW50KTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZWxzZSB7XHJcbiAgICAgICAgICAgIGNvbnRleHQub3BlbkRyb3Bkb3duKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgbGV0IGljb25Qb3NpdGlvblRvVXNlO1xyXG4gICAgaWYgKHByb3BzLmljb24pIHtcclxuICAgICAgICBpY29uUG9zaXRpb25Ub1VzZSA9IGljb25Qb3NpdGlvbiA/PyBCdXR0b25JY29uUG9zaXRpb24ubGVmdDtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIGljb25Qb3NpdGlvblRvVXNlID1cclxuICAgICAgICAgICAgY29udGV4dC5kcm9wRGlyZWN0aW9uID09PSBEcm9wZG93bkRyb3BEaXJlY3Rpb24ubGVmdFxyXG4gICAgICAgICAgICAgICAgPyBCdXR0b25JY29uUG9zaXRpb24ubGVmdFxyXG4gICAgICAgICAgICAgICAgOiBCdXR0b25JY29uUG9zaXRpb24ucmlnaHQ7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyByZWY6IGNvbnRleHQuc2V0UmVmZXJlbmNlIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRJY29uQnV0dG9uLCBPYmplY3QuYXNzaWduKHt9LCBvdGhlciwgeyBcImFyaWEtY29udHJvbHNcIjogKGlkID8/IGNvbnRleHQuZHJvcGRvd25CdXR0b25JZC5jdXJyZW50KSArICdfZHJvcGRvd25NZW51SWQnLCBcImFyaWEtZXhwYW5kZWRcIjogY29udGV4dC5pc09wZW4sIFwiYXJpYS1oYXNwb3B1cFwiOiBcInRydWVcIiwgaWNvbjogaWNvbiwgaWNvblBvc2l0aW9uOiBpY29uUG9zaXRpb25Ub1VzZSwgaWQ6IGlkID8/IGNvbnRleHQuZHJvcGRvd25CdXR0b25JZC5jdXJyZW50LCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlLCBsZWFkaW5nSWNvbjogbGVhZGluZ0ljb24sIG9uQ2xpY2s6IGhhbmRsZUNsaWNrLCByZWY6IHJlZiwgdGhlbWU6IHRoZW1lIH0pLCBjaGlsZHJlbikpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPURyb3Bkb3duQnV0dG9uLmpzLm1hcCJdfQ== */"));
|
|
9862
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duQnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxQjRDIiwiZmlsZSI6IkRyb3Bkb3duQnV0dG9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XHJcbmltcG9ydCB7IEFycm93RHJvcERvd25JY29uLCBBcnJvd0Ryb3BVcEljb24sIEFycm93TGVmdEljb24sIEFycm93UmlnaHRJY29uLCB9IGZyb20gJ3JlYWN0LW1hZ21hLWljb25zJztcclxuaW1wb3J0IHsgQnV0dG9uSWNvblBvc2l0aW9uLCBJY29uQnV0dG9uIH0gZnJvbSAnLi4vSWNvbkJ1dHRvbic7XHJcbmltcG9ydCB7IERyb3Bkb3duQ29udGV4dCwgRHJvcGRvd25Ecm9wRGlyZWN0aW9uIH0gZnJvbSAnLi9Ecm9wZG93bic7XHJcbmltcG9ydCB7IFRoZW1lQ29udGV4dCB9IGZyb20gJy4uLy4uL3RoZW1lL1RoZW1lQ29udGV4dCc7XHJcbmltcG9ydCB7IHVzZUZvcmtlZFJlZiB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuZnVuY3Rpb24gaW5zdGFuY2VPZkljb25Pbmx5RHJvcGRvd25CdXR0b24ob2JqZWN0KSB7XHJcbiAgICByZXR1cm4gJ2ljb24nIGluIG9iamVjdCAmJiAhKCdjaGlsZHJlbicgaW4gb2JqZWN0KTtcclxufVxyXG5mdW5jdGlvbiBnZXRCdXR0b25QYWRkaW5nKHRoZW1lLCBzaXplKSB7XHJcbiAgICBzd2l0Y2ggKHNpemUpIHtcclxuICAgICAgICBjYXNlICdzbWFsbCc6XHJcbiAgICAgICAgICAgIHJldHVybiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwMjtcclxuICAgICAgICBjYXNlICdsYXJnZSc6XHJcbiAgICAgICAgICAgIHJldHVybiB0aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwNTtcclxuICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICByZXR1cm4gdGhlbWUuc3BhY2VTY2FsZS5zcGFjaW5nMDM7XHJcbiAgICB9XHJcbn1cclxuY29uc3QgU3R5bGVkSWNvbkJ1dHRvbiA9IHN0eWxlZChJY29uQnV0dG9uKSBgXG4gICR7cHJvcHMgPT4gcHJvcHMuaWNvblBvc2l0aW9uID09PSBCdXR0b25JY29uUG9zaXRpb24ucmlnaHQgJiZcclxuICAgIHByb3BzLmNoaWxkcmVuICYmXHJcbiAgICBjc3MgYFxuICAgICAgcGFkZGluZy1yaWdodDogJHtnZXRCdXR0b25QYWRkaW5nKHByb3BzLnRoZW1lLCBwcm9wcy5zaXplKX07XG4gICAgYH1cbiAgJHtwcm9wcyA9PiBwcm9wcy5pY29uUG9zaXRpb24gPT09IEJ1dHRvbkljb25Qb3NpdGlvbi5sZWZ0ICYmXHJcbiAgICBwcm9wcy5jaGlsZHJlbiAmJlxyXG4gICAgY3NzIGBcbiAgICAgIHBhZGRpbmctbGVmdDogJHtnZXRCdXR0b25QYWRkaW5nKHByb3BzLnRoZW1lLCBwcm9wcy5zaXplKX07XG4gICAgYH1cbmA7XHJcbmV4cG9ydCBjb25zdCBEcm9wZG93bkJ1dHRvbiA9IFJlYWN0LmZvcndhcmRSZWYoKHByb3BzLCBmb3J3YXJkZWRSZWYpID0+IHtcclxuICAgIGNvbnN0IGNvbnRleHQgPSBSZWFjdC51c2VDb250ZXh0KERyb3Bkb3duQ29udGV4dCk7XHJcbiAgICBjb25zdCB0aGVtZSA9IFJlYWN0LnVzZUNvbnRleHQoVGhlbWVDb250ZXh0KTtcclxuICAgIGNvbnN0IHJlZiA9IHVzZUZvcmtlZFJlZihjb250ZXh0LnRvZ2dsZVJlZiwgZm9yd2FyZGVkUmVmKTtcclxuICAgIGZ1bmN0aW9uIGdldEJ1dHRvbkljb24oZHJvcERpcmVjdGlvbikge1xyXG4gICAgICAgIHN3aXRjaCAoZHJvcERpcmVjdGlvbikge1xyXG4gICAgICAgICAgICBjYXNlIERyb3Bkb3duRHJvcERpcmVjdGlvbi5sZWZ0OlxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQXJyb3dMZWZ0SWNvbiwgeyB0ZXN0SWQ6IFwiY2FyZXRMZWZ0XCIsIFwiYXJpYS1oaWRkZW5cIjogXCJ0cnVlXCIgfSk7XHJcbiAgICAgICAgICAgIGNhc2UgRHJvcGRvd25Ecm9wRGlyZWN0aW9uLnJpZ2h0OlxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQXJyb3dSaWdodEljb24sIHsgdGVzdElkOiBcImNhcmV0UmlnaHRcIiwgXCJhcmlhLWhpZGRlblwiOiBcInRydWVcIiB9KTtcclxuICAgICAgICAgICAgY2FzZSBEcm9wZG93bkRyb3BEaXJlY3Rpb24udXA6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChBcnJvd0Ryb3BVcEljb24sIHsgdGVzdElkOiBcImNhcmV0VXBcIiwgXCJhcmlhLWhpZGRlblwiOiBcInRydWVcIiB9KTtcclxuICAgICAgICAgICAgZGVmYXVsdDpcclxuICAgICAgICAgICAgICAgIHJldHVybiBSZWFjdC5jcmVhdGVFbGVtZW50KEFycm93RHJvcERvd25JY29uLCB7IHRlc3RJZDogXCJjYXJldERvd25cIiwgXCJhcmlhLWhpZGRlblwiOiBcInRydWVcIiB9KTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbiAgICBjb25zdCBidXR0b25JY29uID0gZ2V0QnV0dG9uSWNvbihjb250ZXh0LmRyb3BEaXJlY3Rpb24pO1xyXG4gICAgbGV0IGNoaWxkcmVuO1xyXG4gICAgY29uc3QgeyBpY29uID0gYnV0dG9uSWNvbiwgaWNvblBvc2l0aW9uLCBsZWFkaW5nSWNvbiwgaWQsIC4uLm90aGVyIH0gPSBwcm9wcztcclxuICAgIGlmICghaW5zdGFuY2VPZkljb25Pbmx5RHJvcGRvd25CdXR0b24ocHJvcHMpKSB7XHJcbiAgICAgICAgY2hpbGRyZW4gPSBwcm9wcy5jaGlsZHJlbjtcclxuICAgIH1cclxuICAgIGZ1bmN0aW9uIGhhbmRsZUNsaWNrKGV2ZW50KSB7XHJcbiAgICAgICAgaWYgKGNvbnRleHQuaXNPcGVuKSB7XHJcbiAgICAgICAgICAgIGNvbnRleHQuY2xvc2VEcm9wZG93bihldmVudCk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICBjb250ZXh0Lm9wZW5Ecm9wZG93bigpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIGxldCBpY29uUG9zaXRpb25Ub1VzZTtcclxuICAgIGlmIChwcm9wcy5pY29uKSB7XHJcbiAgICAgICAgaWNvblBvc2l0aW9uVG9Vc2UgPSBpY29uUG9zaXRpb24gPz8gQnV0dG9uSWNvblBvc2l0aW9uLmxlZnQ7XHJcbiAgICB9XHJcbiAgICBlbHNlIHtcclxuICAgICAgICBpY29uUG9zaXRpb25Ub1VzZSA9XHJcbiAgICAgICAgICAgIGNvbnRleHQuZHJvcERpcmVjdGlvbiA9PT0gRHJvcGRvd25Ecm9wRGlyZWN0aW9uLmxlZnRcclxuICAgICAgICAgICAgICAgID8gQnV0dG9uSWNvblBvc2l0aW9uLmxlZnRcclxuICAgICAgICAgICAgICAgIDogQnV0dG9uSWNvblBvc2l0aW9uLnJpZ2h0O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHsgcmVmOiBjb250ZXh0LnNldFJlZmVyZW5jZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkSWNvbkJ1dHRvbiwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgXCJhcmlhLWNvbnRyb2xzXCI6IChpZCA/PyBjb250ZXh0LmRyb3Bkb3duQnV0dG9uSWQuY3VycmVudCkgKyAnX2Ryb3Bkb3duTWVudUlkJywgXCJhcmlhLWV4cGFuZGVkXCI6IGNvbnRleHQuaXNPcGVuLCBcImFyaWEtaGFzcG9wdXBcIjogXCJ0cnVlXCIsIGljb246IGljb24sIGljb25Qb3NpdGlvbjogaWNvblBvc2l0aW9uVG9Vc2UsIGlkOiBpZCA/PyBjb250ZXh0LmRyb3Bkb3duQnV0dG9uSWQuY3VycmVudCwgaXNJbnZlcnNlOiBjb250ZXh0LmlzSW52ZXJzZSwgbGVhZGluZ0ljb246IGxlYWRpbmdJY29uLCBvbkNsaWNrOiBoYW5kbGVDbGljaywgcmVmOiByZWYsIHRoZW1lOiB0aGVtZSB9KSwgY2hpbGRyZW4pKSk7XHJcbn0pO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Ecm9wZG93bkJ1dHRvbi5qcy5tYXAiXX0= */"));
|
|
9841
9863
|
var DropdownButton = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
9842
9864
|
var context = React.useContext(DropdownContext);
|
|
9843
9865
|
var theme = React.useContext(ThemeContext);
|
|
9844
|
-
context.dropdownButtonId.current = useGenerateId(props.id);
|
|
9845
9866
|
var ref = useForkedRef(context.toggleRef, forwardedRef);
|
|
9846
9867
|
function getButtonIcon(dropDirection) {
|
|
9847
9868
|
switch (dropDirection) {
|
|
@@ -9873,6 +9894,7 @@ var DropdownButton = /*#__PURE__*/React.forwardRef(function (props, forwardedRef
|
|
|
9873
9894
|
icon = _props$icon === void 0 ? buttonIcon : _props$icon,
|
|
9874
9895
|
iconPosition = props.iconPosition,
|
|
9875
9896
|
leadingIcon = props.leadingIcon,
|
|
9897
|
+
id = props.id,
|
|
9876
9898
|
other = _objectWithoutPropertiesLoose(props, _excluded$R);
|
|
9877
9899
|
if (!instanceOfIconOnlyDropdownButton(props)) {
|
|
9878
9900
|
children = props.children;
|
|
@@ -9893,11 +9915,12 @@ var DropdownButton = /*#__PURE__*/React.forwardRef(function (props, forwardedRef
|
|
|
9893
9915
|
return /*#__PURE__*/React.createElement("div", {
|
|
9894
9916
|
ref: context.setReference
|
|
9895
9917
|
}, /*#__PURE__*/React.createElement(StyledIconButton, Object.assign({}, other, {
|
|
9918
|
+
"aria-controls": (id != null ? id : context.dropdownButtonId.current) + '_dropdownMenuId',
|
|
9896
9919
|
"aria-expanded": context.isOpen,
|
|
9897
9920
|
"aria-haspopup": "true",
|
|
9898
9921
|
icon: icon,
|
|
9899
9922
|
iconPosition: iconPositionToUse,
|
|
9900
|
-
id: context.dropdownButtonId.current,
|
|
9923
|
+
id: id != null ? id : context.dropdownButtonId.current,
|
|
9901
9924
|
isInverse: context.isInverse,
|
|
9902
9925
|
leadingIcon: leadingIcon,
|
|
9903
9926
|
onClick: handleClick,
|
|
@@ -9906,7 +9929,7 @@ var DropdownButton = /*#__PURE__*/React.forwardRef(function (props, forwardedRef
|
|
|
9906
9929
|
}), children));
|
|
9907
9930
|
});
|
|
9908
9931
|
|
|
9909
|
-
var _excluded$S = ["children", "testId"];
|
|
9932
|
+
var _excluded$S = ["children", "testId", "id"];
|
|
9910
9933
|
var StyledCard$3 = /*#__PURE__*/_styled(Card, {
|
|
9911
9934
|
target: "e1jb4iof0",
|
|
9912
9935
|
label: "StyledCard"
|
|
@@ -9923,11 +9946,12 @@ var StyledCard$3 = /*#__PURE__*/_styled(Card, {
|
|
|
9923
9946
|
}, " 0;transition:opacity 0.3s;white-space:nowrap;&:focus{outline:2px solid ", function (props) {
|
|
9924
9947
|
return props.isInverse ? props.theme.colors.focusInverse : props.theme.colors.focus;
|
|
9925
9948
|
}, ";outline-offset:0;}", function (props) {
|
|
9926
|
-
return props.width && /*#__PURE__*/react.css("white-space:normal;width:", props.width, ";;label:StyledCard;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJRIiwiZmlsZSI6IkRyb3Bkb3duQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBDYXJkIH0gZnJvbSAnLi4vQ2FyZCc7XHJcbmltcG9ydCB7IERyb3Bkb3duQ29udGV4dCwgfSBmcm9tICcuL0Ryb3Bkb3duJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkKENhcmQpIGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk1MDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBkaXNwbGF5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnYmxvY2snIDogJ25vbmUnKX07XG4gIG1heC1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMubWF4SGVpZ2h0ID8gcHJvcHMubWF4SGVpZ2h0IDogcHJvcHMudGhlbWUuZHJvcGRvd24uY29udGVudC5tYXhIZWlnaHR9O1xuICBvcGFjaXR5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnMScgOiAnMCcpfTtcbiAgb3V0bGluZTogMDtcbiAgb3ZlcmZsb3cteTogYXV0bztcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMDtcbiAgdHJhbnNpdGlvbjogb3BhY2l0eSAwLjNzO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/
|
|
9927
|
-
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT2dDIiwiZmlsZSI6IkRyb3Bkb3duQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBDYXJkIH0gZnJvbSAnLi4vQ2FyZCc7XHJcbmltcG9ydCB7IERyb3Bkb3duQ29udGV4dCwgfSBmcm9tICcuL0Ryb3Bkb3duJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkKENhcmQpIGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk1MDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBkaXNwbGF5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnYmxvY2snIDogJ25vbmUnKX07XG4gIG1heC1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMubWF4SGVpZ2h0ID8gcHJvcHMubWF4SGVpZ2h0IDogcHJvcHMudGhlbWUuZHJvcGRvd24uY29udGVudC5tYXhIZWlnaHR9O1xuICBvcGFjaXR5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnMScgOiAnMCcpfTtcbiAgb3V0bGluZTogMDtcbiAgb3ZlcmZsb3cteTogYXV0bztcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMDtcbiAgdHJhbnNpdGlvbjogb3BhY2l0eSAwLjNzO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/
|
|
9949
|
+
return props.width && /*#__PURE__*/react.css("white-space:normal;width:", props.width, ";;label:StyledCard;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJRIiwiZmlsZSI6IkRyb3Bkb3duQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBDYXJkIH0gZnJvbSAnLi4vQ2FyZCc7XHJcbmltcG9ydCB7IERyb3Bkb3duQ29udGV4dCwgfSBmcm9tICcuL0Ryb3Bkb3duJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkKENhcmQpIGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk1MDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBkaXNwbGF5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnYmxvY2snIDogJ25vbmUnKX07XG4gIG1heC1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMubWF4SGVpZ2h0ID8gcHJvcHMubWF4SGVpZ2h0IDogcHJvcHMudGhlbWUuZHJvcGRvd24uY29udGVudC5tYXhIZWlnaHR9O1xuICBvcGFjaXR5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnMScgOiAnMCcpfTtcbiAgb3V0bGluZTogMDtcbiAgb3ZlcmZsb3cteTogYXV0bztcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMDtcbiAgdHJhbnNpdGlvbjogb3BhY2l0eSAwLjNzO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2VcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICBvdXRsaW5lLW9mZnNldDogMDtcbiAgfVxuXG4gICR7cHJvcHMgPT4gcHJvcHMud2lkdGggJiZcclxuICAgIGNzcyBgXG4gICAgICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICAgICAgd2lkdGg6ICR7cHJvcHMud2lkdGh9O1xuICAgIGB9XG5gO1xyXG5leHBvcnQgY29uc3QgRHJvcGRvd25Db250ZW50ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIGZvcndhcmRlZFJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdGVzdElkLCBpZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgY29udGV4dCA9IFJlYWN0LnVzZUNvbnRleHQoRHJvcGRvd25Db250ZXh0KTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGZvcndhcmRlZFJlZiwgY29udGV4dC5tZW51UmVmKTtcclxuICAgIGxldCBoYXNJdGVtQ2hpbGRyZW4gPSBmYWxzZTtcclxuICAgIC8vIEZvciBFeHBhbmRhYmxlIERyb3Bkb3ducyB0aGF0IGRvbid0IHJlcXVpcmUgYSBtYXgtaGVpZ2h0XHJcbiAgICBsZXQgaGFzRXhwYW5kYWJsZUl0ZW1zID0gZmFsc2U7XHJcbiAgICBSZWFjdC5DaGlsZHJlbi5mb3JFYWNoKGNoaWxkcmVuLCAoY2hpbGQpID0+IHtcclxuICAgICAgICBpZiAoY2hpbGQ/LnR5cGU/LmRpc3BsYXlOYW1lID09PSAnRHJvcGRvd25NZW51SXRlbScgfHxcclxuICAgICAgICAgICAgY2hpbGQ/LnR5cGU/LmRpc3BsYXlOYW1lID09PSAnRHJvcGRvd25NZW51R3JvdXAnKSB7XHJcbiAgICAgICAgICAgIGhhc0l0ZW1DaGlsZHJlbiA9IHRydWU7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChjaGlsZC50eXBlPy5kaXNwbGF5TmFtZSA9PT0gJ0Ryb3Bkb3duRXhwYW5kYWJsZU1lbnVHcm91cCcpIHtcclxuICAgICAgICAgICAgaGFzRXhwYW5kYWJsZUl0ZW1zID0gdHJ1ZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyBcImRhdGEtdGVzdGlkXCI6ICdkcm9wZG93bkNvbnRlbnRXcmFwcGVyJywgaWQ6IChpZCA/PyBjb250ZXh0LmRyb3Bkb3duQnV0dG9uSWQuY3VycmVudCkgKyAnX2Ryb3Bkb3duTWVudUlkJywgcmVmOiBlbCA9PiB7XHJcbiAgICAgICAgICAgIGNvbnRleHQuaXNPcGVuICYmIGNvbnRleHQuc2V0RmxvYXRpbmcoZWwpO1xyXG4gICAgICAgIH0sIFxyXG4gICAgICAgIC8vIHotaW5kZXggOTk2IGlzIHVzZWQgdG8gbWFrZSB0aGUgY29udGVudCBhcHBlYXIgYWJvdmUgZG9jcyBlbGVtZW50cyAoY29kZSBibG9ja3MpXHJcbiAgICAgICAgLy8gYW5kIGJlbG93IHRoZSBNb2RhbCBjb21wb25lbnQgKHotaW5kZXggOTk3KVxyXG4gICAgICAgIHN0eWxlOiB7IC4uLmNvbnRleHQuZmxvYXRpbmdTdHlsZXMsIHpJbmRleDogJzk5NicgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQ2FyZCwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgYWxpZ25tZW50OiBjb250ZXh0LmFsaWdubWVudCwgZHJvcERpcmVjdGlvbjogY29udGV4dC5kcm9wRGlyZWN0aW9uLCBoYXNEcm9wU2hhZG93OiB0cnVlLCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlLCBpc09wZW46IGNvbnRleHQuaXNPcGVuLCBtYXhIZWlnaHQ6IGNvbnRleHQubWF4SGVpZ2h0LCByZWY6IHJlZiwgc3R5bGU6IGhhc0V4cGFuZGFibGVJdGVtc1xyXG4gICAgICAgICAgICAgICAgPyB7IG1heEhlaWdodDogJ2luaGVyaXQnLCBvdmVyZmxvdzogJ2hpZGRlbicgfVxyXG4gICAgICAgICAgICAgICAgOiBwcm9wcy5zdHlsZSwgdGFiSW5kZXg6IC0xLCB0ZXN0SWQ6IHRlc3RJZCA/PyAnZHJvcGRvd25Db250ZW50JywgdGhlbWU6IHRoZW1lLCB3aWR0aDogY29udGV4dC53aWR0aCB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7IFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGlkID8/IGNvbnRleHQuZHJvcGRvd25CdXR0b25JZC5jdXJyZW50LCByb2xlOiBoYXNJdGVtQ2hpbGRyZW4gPyAnbWVudScgOiBudWxsIH0sIGNoaWxkcmVuKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPURyb3Bkb3duQ29udGVudC5qcy5tYXAiXX0= */"));
|
|
9950
|
+
}, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRyb3Bkb3duQ29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT2dDIiwiZmlsZSI6IkRyb3Bkb3duQ29udGVudC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xyXG5pbXBvcnQgeyBDYXJkIH0gZnJvbSAnLi4vQ2FyZCc7XHJcbmltcG9ydCB7IERyb3Bkb3duQ29udGV4dCwgfSBmcm9tICcuL0Ryb3Bkb3duJztcclxuaW1wb3J0IHsgVGhlbWVDb250ZXh0IH0gZnJvbSAnLi4vLi4vdGhlbWUvVGhlbWVDb250ZXh0JztcclxuaW1wb3J0IHsgdXNlRm9ya2VkUmVmIH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5jb25zdCBTdHlsZWRDYXJkID0gc3R5bGVkKENhcmQpIGBcbiAgYmFja2dyb3VuZDogJHtwcm9wcyA9PiBwcm9wcy5pc0ludmVyc2VcclxuICAgID8gcHJvcHMudGhlbWUuY29sb3JzLnByaW1hcnk1MDBcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLm5ldXRyYWwxMDB9O1xuICBkaXNwbGF5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnYmxvY2snIDogJ25vbmUnKX07XG4gIG1heC1oZWlnaHQ6ICR7cHJvcHMgPT4gcHJvcHMubWF4SGVpZ2h0ID8gcHJvcHMubWF4SGVpZ2h0IDogcHJvcHMudGhlbWUuZHJvcGRvd24uY29udGVudC5tYXhIZWlnaHR9O1xuICBvcGFjaXR5OiAke3Byb3BzID0+IChwcm9wcy5pc09wZW4gPyAnMScgOiAnMCcpfTtcbiAgb3V0bGluZTogMDtcbiAgb3ZlcmZsb3cteTogYXV0bztcbiAgcGFkZGluZzogJHtwcm9wcyA9PiBwcm9wcy50aGVtZS5zcGFjZVNjYWxlLnNwYWNpbmcwM30gMDtcbiAgdHJhbnNpdGlvbjogb3BhY2l0eSAwLjNzO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAmOmZvY3VzIHtcbiAgICBvdXRsaW5lOiAycHggc29saWRcbiAgICAgICR7cHJvcHMgPT4gcHJvcHMuaXNJbnZlcnNlXHJcbiAgICA/IHByb3BzLnRoZW1lLmNvbG9ycy5mb2N1c0ludmVyc2VcclxuICAgIDogcHJvcHMudGhlbWUuY29sb3JzLmZvY3VzfTtcbiAgICBvdXRsaW5lLW9mZnNldDogMDtcbiAgfVxuXG4gICR7cHJvcHMgPT4gcHJvcHMud2lkdGggJiZcclxuICAgIGNzcyBgXG4gICAgICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICAgICAgd2lkdGg6ICR7cHJvcHMud2lkdGh9O1xuICAgIGB9XG5gO1xyXG5leHBvcnQgY29uc3QgRHJvcGRvd25Db250ZW50ID0gUmVhY3QuZm9yd2FyZFJlZigocHJvcHMsIGZvcndhcmRlZFJlZikgPT4ge1xyXG4gICAgY29uc3QgeyBjaGlsZHJlbiwgdGVzdElkLCBpZCwgLi4ub3RoZXIgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgY29udGV4dCA9IFJlYWN0LnVzZUNvbnRleHQoRHJvcGRvd25Db250ZXh0KTtcclxuICAgIGNvbnN0IHRoZW1lID0gUmVhY3QudXNlQ29udGV4dChUaGVtZUNvbnRleHQpO1xyXG4gICAgY29uc3QgcmVmID0gdXNlRm9ya2VkUmVmKGZvcndhcmRlZFJlZiwgY29udGV4dC5tZW51UmVmKTtcclxuICAgIGxldCBoYXNJdGVtQ2hpbGRyZW4gPSBmYWxzZTtcclxuICAgIC8vIEZvciBFeHBhbmRhYmxlIERyb3Bkb3ducyB0aGF0IGRvbid0IHJlcXVpcmUgYSBtYXgtaGVpZ2h0XHJcbiAgICBsZXQgaGFzRXhwYW5kYWJsZUl0ZW1zID0gZmFsc2U7XHJcbiAgICBSZWFjdC5DaGlsZHJlbi5mb3JFYWNoKGNoaWxkcmVuLCAoY2hpbGQpID0+IHtcclxuICAgICAgICBpZiAoY2hpbGQ/LnR5cGU/LmRpc3BsYXlOYW1lID09PSAnRHJvcGRvd25NZW51SXRlbScgfHxcclxuICAgICAgICAgICAgY2hpbGQ/LnR5cGU/LmRpc3BsYXlOYW1lID09PSAnRHJvcGRvd25NZW51R3JvdXAnKSB7XHJcbiAgICAgICAgICAgIGhhc0l0ZW1DaGlsZHJlbiA9IHRydWU7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGlmIChjaGlsZC50eXBlPy5kaXNwbGF5TmFtZSA9PT0gJ0Ryb3Bkb3duRXhwYW5kYWJsZU1lbnVHcm91cCcpIHtcclxuICAgICAgICAgICAgaGFzRXhwYW5kYWJsZUl0ZW1zID0gdHJ1ZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgfSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyBcImRhdGEtdGVzdGlkXCI6ICdkcm9wZG93bkNvbnRlbnRXcmFwcGVyJywgaWQ6IChpZCA/PyBjb250ZXh0LmRyb3Bkb3duQnV0dG9uSWQuY3VycmVudCkgKyAnX2Ryb3Bkb3duTWVudUlkJywgcmVmOiBlbCA9PiB7XHJcbiAgICAgICAgICAgIGNvbnRleHQuaXNPcGVuICYmIGNvbnRleHQuc2V0RmxvYXRpbmcoZWwpO1xyXG4gICAgICAgIH0sIFxyXG4gICAgICAgIC8vIHotaW5kZXggOTk2IGlzIHVzZWQgdG8gbWFrZSB0aGUgY29udGVudCBhcHBlYXIgYWJvdmUgZG9jcyBlbGVtZW50cyAoY29kZSBibG9ja3MpXHJcbiAgICAgICAgLy8gYW5kIGJlbG93IHRoZSBNb2RhbCBjb21wb25lbnQgKHotaW5kZXggOTk3KVxyXG4gICAgICAgIHN0eWxlOiB7IC4uLmNvbnRleHQuZmxvYXRpbmdTdHlsZXMsIHpJbmRleDogJzk5NicgfSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQ2FyZCwgT2JqZWN0LmFzc2lnbih7fSwgb3RoZXIsIHsgYWxpZ25tZW50OiBjb250ZXh0LmFsaWdubWVudCwgZHJvcERpcmVjdGlvbjogY29udGV4dC5kcm9wRGlyZWN0aW9uLCBoYXNEcm9wU2hhZG93OiB0cnVlLCBpc0ludmVyc2U6IGNvbnRleHQuaXNJbnZlcnNlLCBpc09wZW46IGNvbnRleHQuaXNPcGVuLCBtYXhIZWlnaHQ6IGNvbnRleHQubWF4SGVpZ2h0LCByZWY6IHJlZiwgc3R5bGU6IGhhc0V4cGFuZGFibGVJdGVtc1xyXG4gICAgICAgICAgICAgICAgPyB7IG1heEhlaWdodDogJ2luaGVyaXQnLCBvdmVyZmxvdzogJ2hpZGRlbicgfVxyXG4gICAgICAgICAgICAgICAgOiBwcm9wcy5zdHlsZSwgdGFiSW5kZXg6IC0xLCB0ZXN0SWQ6IHRlc3RJZCA/PyAnZHJvcGRvd25Db250ZW50JywgdGhlbWU6IHRoZW1lLCB3aWR0aDogY29udGV4dC53aWR0aCB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7IFwiYXJpYS1sYWJlbGxlZGJ5XCI6IGlkID8/IGNvbnRleHQuZHJvcGRvd25CdXR0b25JZC5jdXJyZW50LCByb2xlOiBoYXNJdGVtQ2hpbGRyZW4gPyAnbWVudScgOiBudWxsIH0sIGNoaWxkcmVuKSkpKTtcclxufSk7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPURyb3Bkb3duQ29udGVudC5qcy5tYXAiXX0= */"));
|
|
9928
9951
|
var DropdownContent = /*#__PURE__*/React.forwardRef(function (props, forwardedRef) {
|
|
9929
9952
|
var children = props.children,
|
|
9930
9953
|
testId = props.testId,
|
|
9954
|
+
id = props.id,
|
|
9931
9955
|
other = _objectWithoutPropertiesLoose(props, _excluded$S);
|
|
9932
9956
|
var context = React.useContext(DropdownContext);
|
|
9933
9957
|
var theme = React.useContext(ThemeContext);
|
|
@@ -9947,6 +9971,7 @@ var DropdownContent = /*#__PURE__*/React.forwardRef(function (props, forwardedRe
|
|
|
9947
9971
|
});
|
|
9948
9972
|
return /*#__PURE__*/React.createElement("div", {
|
|
9949
9973
|
"data-testid": 'dropdownContentWrapper',
|
|
9974
|
+
id: (id != null ? id : context.dropdownButtonId.current) + '_dropdownMenuId',
|
|
9950
9975
|
ref: function ref(el) {
|
|
9951
9976
|
context.isOpen && context.setFloating(el);
|
|
9952
9977
|
},
|
|
@@ -9972,7 +9997,7 @@ var DropdownContent = /*#__PURE__*/React.forwardRef(function (props, forwardedRe
|
|
|
9972
9997
|
theme: theme,
|
|
9973
9998
|
width: context.width
|
|
9974
9999
|
}), /*#__PURE__*/React.createElement("div", {
|
|
9975
|
-
"aria-labelledby": context.dropdownButtonId.current,
|
|
10000
|
+
"aria-labelledby": id != null ? id : context.dropdownButtonId.current,
|
|
9976
10001
|
role: hasItemChildren ? 'menu' : null
|
|
9977
10002
|
}, children)));
|
|
9978
10003
|
});
|
|
@@ -10272,6 +10297,7 @@ var DropdownSplitButton = /*#__PURE__*/React.forwardRef(function (props, forward
|
|
|
10272
10297
|
}, leadingIcon ? (/*#__PURE__*/React.createElement(IconButton, Object.assign({}, sharedButtonProps, {
|
|
10273
10298
|
icon: leadingIcon
|
|
10274
10299
|
}), children)) : (/*#__PURE__*/React.createElement(Button, Object.assign({}, sharedButtonProps), children)), /*#__PURE__*/React.createElement(IconButton, Object.assign({}, other, {
|
|
10300
|
+
"aria-controls": (id != null ? id : context.dropdownButtonId.current) + '_dropdownMenuId',
|
|
10275
10301
|
"aria-expanded": resolvedContext.isOpen,
|
|
10276
10302
|
"aria-label": ariaLabel || i18n.dropdown.toggleMenuAriaLabel,
|
|
10277
10303
|
"aria-haspopup": "true",
|