@amboss/design-system 3.41.2 → 3.42.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/build/cjs/components/ColorPicker/ColorPicker.d.ts +2 -1
  2. package/build/cjs/components/ColorPicker/ColorPicker.js +1 -1
  3. package/build/cjs/components/EntityList/EntityListItem.js +1 -1
  4. package/build/cjs/components/Form/SegmentedControl/-types.d.ts +6 -0
  5. package/build/cjs/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  6. package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.d.ts +1 -1
  7. package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  8. package/build/cjs/components/Form/ToolbarToggle/-types.d.ts +9 -0
  9. package/build/cjs/components/Form/ToolbarToggle/-types.js +1 -0
  10. package/build/cjs/components/Form/ToolbarToggle/ToolbarToggle.d.ts +4 -0
  11. package/build/cjs/components/Form/ToolbarToggle/ToolbarToggle.js +1 -0
  12. package/build/cjs/components/Toggletip/BasePopover.d.ts +3 -1
  13. package/build/cjs/components/Toggletip/BasePopover.js +1 -1
  14. package/build/cjs/index.d.ts +1 -0
  15. package/build/cjs/index.js +1 -1
  16. package/build/esm/components/ColorPicker/ColorPicker.d.ts +2 -1
  17. package/build/esm/components/ColorPicker/ColorPicker.js +1 -1
  18. package/build/esm/components/EntityList/EntityListItem.js +1 -1
  19. package/build/esm/components/Form/SegmentedControl/-types.d.ts +6 -0
  20. package/build/esm/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  21. package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.d.ts +1 -1
  22. package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  23. package/build/esm/components/Form/ToolbarToggle/-types.d.ts +9 -0
  24. package/build/esm/components/Form/ToolbarToggle/-types.js +1 -0
  25. package/build/esm/components/Form/ToolbarToggle/ToolbarToggle.d.ts +4 -0
  26. package/build/esm/components/Form/ToolbarToggle/ToolbarToggle.js +1 -0
  27. package/build/esm/components/Toggletip/BasePopover.d.ts +3 -1
  28. package/build/esm/components/Toggletip/BasePopover.js +1 -1
  29. package/build/esm/index.d.ts +1 -0
  30. package/build/esm/index.js +1 -1
  31. package/package.json +1 -1
@@ -10,9 +10,10 @@ export type ColorPickerProps = Pick<ColorPickerOptionProps, "size"> & {
10
10
  alignItems?: InlineProps["alignItems"];
11
11
  colors: Array<ColorOption>;
12
12
  disabled?: boolean;
13
+ focusOnMount?: boolean;
13
14
  onColorSelected: (color: ColorPickerOptionProps["color"]) => void;
14
15
  selectedColor?: ColorPickerOptionProps["color"];
15
16
  /** @deprecated Use aria-* props directly instead */
16
17
  ariaAttributes?: AriaAttributes;
17
18
  };
18
- export declare const ColorPicker: ({ alignItems, colors, onColorSelected, disabled, selectedColor, size, ariaAttributes: deprecatedAriaAttributes, ...ariaAttributes }: ColorPickerProps) => ReactElement;
19
+ export declare const ColorPicker: ({ alignItems, colors, onColorSelected, disabled, focusOnMount, selectedColor, size, ariaAttributes: deprecatedAriaAttributes, ...ariaAttributes }: ColorPickerProps) => ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ColorPicker",{enumerable:!0,get:function(){return ColorPicker}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_Inline=require("../Inline/Inline"),_Button=require("../Button/Button"),_ColorPickerOption=require("./ColorPickerOption"),_useKeyboard=require("../../shared/useKeyboard"),ColorPicker=({alignItems="left",colors,onColorSelected,disabled,selectedColor,size=["m","s"],ariaAttributes:deprecatedAriaAttributes,...ariaAttributes})=>{let selectedIndex=selectedColor?colors.findIndex(c=>c.color===selectedColor):-1,tabbableIndex=selectedIndex>=0?selectedIndex:0,groupRef=(0,_react.useRef)(null),focusedIndex=(0,_react.useRef)(tabbableIndex),focusByDelta=delta=>{let buttons=groupRef.current?.querySelectorAll("[data-color]");if(!buttons)return;let next=(focusedIndex.current+delta+buttons.length)%buttons.length;focusedIndex.current=next,buttons[next]?.focus(),onColorSelected(colors[next].color)};return(0,_useKeyboard.useKeyboard)({"ArrowRight ArrowDown":()=>focusByDelta(1),"ArrowLeft ArrowUp":()=>focusByDelta(-1),"Enter Space":()=>onColorSelected(colors[focusedIndex.current].color)},groupRef,!disabled),_react.default.createElement("div",{ref:groupRef,role:"radiogroup",...deprecatedAriaAttributes,...ariaAttributes},_react.default.createElement(_Inline.Inline,{space:"s"===size?"zero":"xxxs",alignItems:alignItems},colors.map((colorOption,index)=>_react.default.createElement(_Button.Button,{key:colorOption.color,variant:"tertiary",size:"s",onClick:()=>onColorSelected(colorOption.color),onFocus:()=>{focusedIndex.current=index},disabled:disabled,"data-color":colorOption.color,role:"radio","aria-checked":colorOption.color===selectedColor,tabIndex:index===tabbableIndex?0:-1,"aria-label":colorOption.ariaLabel},_react.default.createElement(_ColorPickerOption.ColorPickerOption,{"data-e2e-test-id":"color-indicator",color:colorOption.color,isSelected:colorOption.color===selectedColor,size:size})))))};
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ColorPicker",{enumerable:!0,get:function(){return ColorPicker}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_Inline=require("../Inline/Inline"),_Button=require("../Button/Button"),_ColorPickerOption=require("./ColorPickerOption"),_useKeyboard=require("../../shared/useKeyboard"),ColorPicker=({alignItems="left",colors,onColorSelected,disabled,focusOnMount,selectedColor,size=["m","s"],ariaAttributes:deprecatedAriaAttributes,...ariaAttributes})=>{let selectedIndex=selectedColor?colors.findIndex(c=>c.color===selectedColor):-1,tabbableIndex=selectedIndex>=0?selectedIndex:0,groupRef=(0,_react.useRef)(null),focusedIndex=(0,_react.useRef)(tabbableIndex);(0,_react.useEffect)(()=>{focusOnMount&&groupRef.current?.querySelector("[data-color]")?.focus()},[focusOnMount]);let focusByDelta=delta=>{let buttons=groupRef.current?.querySelectorAll("[data-color]");if(!buttons)return;let next=(focusedIndex.current+delta+buttons.length)%buttons.length;focusedIndex.current=next,buttons[next]?.focus(),onColorSelected(colors[next].color)};return(0,_useKeyboard.useKeyboard)({"ArrowRight ArrowDown":()=>focusByDelta(1),"ArrowLeft ArrowUp":()=>focusByDelta(-1),"Enter Space":()=>onColorSelected(colors[focusedIndex.current].color)},groupRef,!disabled),_react.default.createElement("div",{ref:groupRef,role:"radiogroup",...deprecatedAriaAttributes,...ariaAttributes},_react.default.createElement(_Inline.Inline,{space:"s"===size?"zero":"xxxs",alignItems:alignItems},colors.map((colorOption,index)=>_react.default.createElement(_Button.Button,{key:colorOption.color,variant:"tertiary",size:"s",onClick:()=>onColorSelected(colorOption.color),onFocus:()=>{focusedIndex.current=index},disabled:disabled,"data-color":colorOption.color,role:"radio","aria-checked":colorOption.color===selectedColor,tabIndex:index===tabbableIndex?0:-1,"aria-label":colorOption.ariaLabel},_react.default.createElement(_ColorPickerOption.ColorPickerOption,{"data-e2e-test-id":"color-indicator",color:colorOption.color,isSelected:colorOption.color===selectedColor,size:size})))))};
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityListItem",{enumerable:!0,get:function(){return EntityListItem}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_EntityItemBody=require("./EntityItemBody"),_useKeyboard=require("../../shared/useKeyboard"),_styledcomponents=require("./styled-components"),useButtonKeyboard=({ref:globalRef,isActive,onSpaceEnterPress})=>{let localRef=(0,_react.useRef)(null);return(0,_useKeyboard.useKeyboard)({"Space Enter":onSpaceEnterPress},localRef,isActive,!0),(0,_react.useImperativeHandle)(globalRef,()=>localRef.current),localRef},EntityListItem=_react.default.forwardRef(({checkboxProps,description,hideBorder,isActive,isClickable,isDisabled,onClick,renderLabel,renderLeft,renderRight,role,tabIndex,onSpaceEnterPress,size="m","aria-label":ariaLabel,"data-list-item":dataListItem,isSelected},ref)=>{let handleOnClick=(0,_react.useCallback)(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:isClickable&&!isDisabled&&void 0!==tabIndex,onSpaceEnterPress}),supportsAriaSelected="menuitem"!==role;return _react.default.createElement(_styledcomponents.StyledEntityListItemButton,{role:role,"aria-label":ariaLabel,"aria-selected":supportsAriaSelected?isSelected:void 0,"aria-disabled":isDisabled,size:size,tabIndex:tabIndex,ref:buttonRef,"data-list-item":dataListItem,"data-id":"list-item",onClick:handleOnClick,isClickable:isClickable,isActive:isActive,isDisabled:isDisabled},_react.default.createElement(_styledcomponents.StyledEntityListItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},_react.default.createElement(_EntityItemBody.EntityItemBody,{size:size,tabIndex:tabIndex,checkboxProps:checkboxProps,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight})))});
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"EntityListItem",{enumerable:!0,get:function(){return EntityListItem}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_EntityItemBody=require("./EntityItemBody"),_useKeyboard=require("../../shared/useKeyboard"),_styledcomponents=require("./styled-components"),useButtonKeyboard=({ref:globalRef,isActive,onSpaceEnterPress})=>{let localRef=(0,_react.useRef)(null);return(0,_useKeyboard.useKeyboard)({"Space Enter":onSpaceEnterPress},localRef,isActive,!0),(0,_react.useImperativeHandle)(globalRef,()=>localRef.current),localRef},EntityListItem=_react.default.forwardRef(({checkboxProps,description,hideBorder,isActive,isClickable,isDisabled,onClick,renderLabel,renderLeft,renderRight,role,tabIndex,onSpaceEnterPress,size="m","aria-label":ariaLabel,"data-list-item":dataListItem,isSelected},ref)=>{let handleOnClick=(0,_react.useCallback)(e=>{isClickable&&onClick&&onClick(e)},[onClick,isClickable]),buttonRef=useButtonKeyboard({ref,isActive:isClickable&&!isDisabled&&void 0!==tabIndex,onSpaceEnterPress}),supportsAriaSelected="menuitem"!==role,supportsAriaCurrent="option"!==role;return _react.default.createElement(_styledcomponents.StyledEntityListItemButton,{role:role,"aria-label":ariaLabel,"aria-selected":supportsAriaSelected?isSelected:void 0,"aria-current":supportsAriaCurrent&&isActive?isActive:void 0,"aria-disabled":isDisabled,size:size,tabIndex:tabIndex,ref:buttonRef,"data-list-item":dataListItem,"data-id":"list-item",onClick:handleOnClick,isClickable:isClickable,isActive:isActive,isDisabled:isDisabled},_react.default.createElement(_styledcomponents.StyledEntityListItemWrapper,{size:size,hideBorder:hideBorder||"xs"===size},_react.default.createElement(_EntityItemBody.EntityItemBody,{size:size,tabIndex:tabIndex,checkboxProps:checkboxProps,description:description,renderLabel:renderLabel,renderLeft:renderLeft,renderRight:renderRight})))});
@@ -26,6 +26,10 @@ export type SegmentedControlOption = {
26
26
  icon: {
27
27
  ariaLabel?: string;
28
28
  };
29
+ input?: {
30
+ ariaExpanded?: boolean;
31
+ ariaControls?: string;
32
+ };
29
33
  }>;
30
34
  } & ({
31
35
  iconName?: never;
@@ -44,11 +48,13 @@ export type SegmentedControlProps = {
44
48
  justified?: boolean;
45
49
  /** Segment size, not applicable on mobile breakpoint */
46
50
  size?: "s" | "m" | "l";
51
+ /** Callback fired when a segment is selected, with the value of the selected segment. For a single option, it will be called with an empty string when unchecked */
47
52
  onChange: (value: string) => void;
48
53
  renderOptionWrapper?: (props: RenderOptionWrapperProps) => ReactElement;
49
54
  } & Omit<FormFieldGroupProps, "disabled" | "children">;
50
55
  export type SegmentedControlOptionProps = Pick<SegmentedControlProps, "size"> & SegmentedControlOption & {
51
56
  checked: boolean | undefined;
52
57
  isResponsive?: boolean;
58
+ inputType: "radio" | "checkbox";
53
59
  onChange?: (e: ChangeEvent<HTMLInputElement>) => void;
54
60
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControl",{enumerable:!0,get:function(){return SegmentedControl}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),_FormFieldGroup=require("../FormFieldGroup/FormFieldGroup"),_SegmentedControlOption=require("./SegmentedControlOption"),StyledDivider=(0,_styled.default)("div",{target:"e1i699rb0",label:"StyledDivider"})(({theme,isChecked,isDisabled,isPrevOptionChecked,isPrevOptionDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,otherStyles={backgroundColor:theme.values.color.background.primary.default,...(isChecked||isPrevOptionChecked)&&{borderColor:theme.values.color.border.accent.default},...isDisabled&&isPrevOptionDisabled&&{opacity:theme.variables.opacity.disabled}},borderRightStyle={borderRight:border,...otherStyles};return justified?{[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{...borderRightStyle},[`@media (max-width: ${_breakpointsjson.default.m.value}px)`]:{borderBottom:border,...otherStyles}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcbmltcG9ydCB0eXBlIHsgU2VnbWVudGVkQ29udHJvbFByb3BzIH0gZnJvbSBcIi4vLXR5cGVzXCI7XG5pbXBvcnQgeyBGb3JtRmllbGRHcm91cCB9IGZyb20gXCIuLi9Gb3JtRmllbGRHcm91cC9Gb3JtRmllbGRHcm91cFwiO1xuaW1wb3J0IHsgU2VnbWVudGVkQ29udHJvbE9wdGlvbiB9IGZyb20gXCIuL1NlZ21lbnRlZENvbnRyb2xPcHRpb25cIjtcblxuZXhwb3J0IHR5cGUgeyBTZWdtZW50ZWRDb250cm9sUHJvcHMgfTtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgLi4uYm9yZGVyUmlnaHRTdHlsZSxcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiBtb2JpbGVcbiAgICAgIFtgQG1lZGlhIChtYXgtd2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4ub3RoZXJTdHlsZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbnR5cGUgU3R5bGVkQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBTZWdtZW50ZWRDb250cm9sUHJvcHMsXG4gIFwianVzdGlmaWVkXCIgfCBcIm9wdGlvbnNcIlxuPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxTdHlsZWRDb250YWluZXJQcm9wcz4oXG4gICh7IGp1c3RpZmllZCwgb3B0aW9ucyB9KSA9PiB7XG4gICAgY29uc3QgYmFzZVN0eWxlID0ge1xuICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgfTtcblxuICAgIGlmICghanVzdGlmaWVkKSB7XG4gICAgICByZXR1cm4gYmFzZVN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5iYXNlU3R5bGUsXG4gICAgICBmbGV4RGlyZWN0aW9uOiBcImNvbHVtblwiLFxuXG4gICAgICBcIiYgPiAqXCI6IHtcbiAgICAgICAgZmxleDogYDEgMSAkezEwMCAvIG9wdGlvbnMubGVuZ3RofSVgLFxuICAgICAgfSxcblxuICAgICAgW2AmID4gJHtTdHlsZWREaXZpZGVyfWBdOiB7XG4gICAgICAgIGZsZXg6IFwiMCAwIGF1dG9cIixcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICByZW5kZXJPcHRpb25XcmFwcGVyLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBpc1ByZXZPcHRpb25DaGVja2VkID0gb3B0aW9uc1tpbmRleCAtIDFdPy52YWx1ZSA9PT0gdmFsdWU7XG4gICAgICBjb25zdCBpc1ByZXZPcHRpb25EaXNhYmxlZCA9IG9wdGlvbnNbaW5kZXggLSAxXT8uZGlzYWJsZWQ7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID0gKFxuICAgICAgICA8U3R5bGVkRGl2aWRlclxuICAgICAgICAgIGlzUHJldk9wdGlvbkNoZWNrZWQ9e2lzUHJldk9wdGlvbkNoZWNrZWR9XG4gICAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ9e2lzUHJldk9wdGlvbkRpc2FibGVkfVxuICAgICAgICAgIGlzQ2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgIGlzRGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIGp1c3RpZmllZD17anVzdGlmaWVkfVxuICAgICAgICAvPlxuICAgICAgKTtcblxuICAgICAgLy8gd2Ugd2FudCB0byBzaG93IGFjdGl2ZSBkaXZpZGVycyBpbiBjaGVja2VkIG9wdGlvblxuICAgICAgLy8gaW4gb3JkZXIgdG8gYXBwbHkgc3VidGhlbWVzXG4gICAgICBjb25zdCBpc0ZpcnN0T3B0aW9uID0gaW5kZXggPT09IDA7XG4gICAgICBjb25zdCBpc0xhc3RPcHRpb24gPSBpbmRleCA9PT0gb3B0aW9ucy5sZW5ndGggLSAxO1xuXG4gICAgICAvLyB3ZSBoaWRlIGRpdmlkZXIgZm9yIGxhc3Qgb3B0aW9uIGFuZCBhbHdheXMgc2hvdyBmb3IgY2hlY2tlZCBvcHRpb25cbiAgICAgIGNvbnN0IGlzUmlnaHREaXZpZGVyID0gIWlzTGFzdE9wdGlvbiAmJiBpc0NoZWNrZWQ7XG5cbiAgICAgIC8vIHdlIGhpZGUgbGVmdCBkaXZpZGVyIGZvciBmaXJzdCBvcHRpb25cbiAgICAgIC8vIHdlIGhpZGUgZ3JheSBkaXZpZGVyIGlmIHByZXZpb3VzIG9wdGlvbiBpcyBjaGVja2VkLFxuICAgICAgLy8gYmVjYXVzZSB0aGVyZSBpcyBpc1JpZ2h0RGl2aWRlciBhbHJlYWR5IGluIHByZXZpb3VzIG9wdGlvblxuICAgICAgY29uc3QgaXNMZWZ0RGl2aWRlciA9ICFpc0ZpcnN0T3B0aW9uICYmICFpc1ByZXZPcHRpb25DaGVja2VkO1xuXG4gICAgICBjb25zdCBvcHRpb25FbG0gPSAoXG4gICAgICAgIDw+XG4gICAgICAgICAge2lzTGVmdERpdmlkZXIgJiYgZGl2aWRlckVsbX1cbiAgICAgICAgICA8U2VnbWVudGVkQ29udHJvbE9wdGlvblxuICAgICAgICAgICAgdmFsdWU9e29wdGlvblZhbHVlfVxuICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgIGNoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICAgIGlzUmVzcG9uc2l2ZT17anVzdGlmaWVkfVxuICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX1cbiAgICAgICAgICAgIHsuLi5vdGhlclByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2lzUmlnaHREaXZpZGVyICYmIGRpdmlkZXJFbG19XG4gICAgICAgIDwvPlxuICAgICAgKTtcblxuICAgICAgY29uc3Qgd3JhcHBlZE9wdGlvbkVsbSA9IHJlbmRlck9wdGlvbldyYXBwZXJcbiAgICAgICAgPyByZW5kZXJPcHRpb25XcmFwcGVyKHtcbiAgICAgICAgICAgIG9wdGlvbjogb3B0aW9uRWxtLFxuICAgICAgICAgICAgY2hlY2tlZDogaXNDaGVja2VkLFxuICAgICAgICAgICAgZGlzYWJsZWQsXG4gICAgICAgICAgICB2YWx1ZTogb3B0aW9uVmFsdWUsXG4gICAgICAgICAgfSlcbiAgICAgICAgOiBvcHRpb25FbG07XG5cbiAgICAgIHJldHVybiA8RnJhZ21lbnQga2V5PXtvcHRpb25WYWx1ZX0+e3dyYXBwZWRPcHRpb25FbG19PC9GcmFnbWVudD47XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZEdyb3VwXG4gICAgICBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiXG4gICAgICBpc0xhYmVsSGlkZGVuPXtpc0xhYmVsSGlkZGVufVxuICAgICAgey4uLnJlc3R9XG4gICAgPlxuICAgICAgPFN0eWxlZENvbnRhaW5lciBqdXN0aWZpZWQ9e2p1c3RpZmllZH0gb3B0aW9ucz17b3B0aW9uc30+XG4gICAgICAgIHtvcHRpb25FbG1zfVxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgPC9Gb3JtRmllbGRHcm91cD5cbiAgKTtcbn1cblxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0JzQiJ9 */"),StyledContainer=(0,_styled.default)("div",{target:"e1i699rb1",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcbmltcG9ydCB0eXBlIHsgU2VnbWVudGVkQ29udHJvbFByb3BzIH0gZnJvbSBcIi4vLXR5cGVzXCI7XG5pbXBvcnQgeyBGb3JtRmllbGRHcm91cCB9IGZyb20gXCIuLi9Gb3JtRmllbGRHcm91cC9Gb3JtRmllbGRHcm91cFwiO1xuaW1wb3J0IHsgU2VnbWVudGVkQ29udHJvbE9wdGlvbiB9IGZyb20gXCIuL1NlZ21lbnRlZENvbnRyb2xPcHRpb25cIjtcblxuZXhwb3J0IHR5cGUgeyBTZWdtZW50ZWRDb250cm9sUHJvcHMgfTtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgLi4uYm9yZGVyUmlnaHRTdHlsZSxcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiBtb2JpbGVcbiAgICAgIFtgQG1lZGlhIChtYXgtd2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4ub3RoZXJTdHlsZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbnR5cGUgU3R5bGVkQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBTZWdtZW50ZWRDb250cm9sUHJvcHMsXG4gIFwianVzdGlmaWVkXCIgfCBcIm9wdGlvbnNcIlxuPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxTdHlsZWRDb250YWluZXJQcm9wcz4oXG4gICh7IGp1c3RpZmllZCwgb3B0aW9ucyB9KSA9PiB7XG4gICAgY29uc3QgYmFzZVN0eWxlID0ge1xuICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgfTtcblxuICAgIGlmICghanVzdGlmaWVkKSB7XG4gICAgICByZXR1cm4gYmFzZVN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5iYXNlU3R5bGUsXG4gICAgICBmbGV4RGlyZWN0aW9uOiBcImNvbHVtblwiLFxuXG4gICAgICBcIiYgPiAqXCI6IHtcbiAgICAgICAgZmxleDogYDEgMSAkezEwMCAvIG9wdGlvbnMubGVuZ3RofSVgLFxuICAgICAgfSxcblxuICAgICAgW2AmID4gJHtTdHlsZWREaXZpZGVyfWBdOiB7XG4gICAgICAgIGZsZXg6IFwiMCAwIGF1dG9cIixcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICByZW5kZXJPcHRpb25XcmFwcGVyLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBpc1ByZXZPcHRpb25DaGVja2VkID0gb3B0aW9uc1tpbmRleCAtIDFdPy52YWx1ZSA9PT0gdmFsdWU7XG4gICAgICBjb25zdCBpc1ByZXZPcHRpb25EaXNhYmxlZCA9IG9wdGlvbnNbaW5kZXggLSAxXT8uZGlzYWJsZWQ7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID0gKFxuICAgICAgICA8U3R5bGVkRGl2aWRlclxuICAgICAgICAgIGlzUHJldk9wdGlvbkNoZWNrZWQ9e2lzUHJldk9wdGlvbkNoZWNrZWR9XG4gICAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ9e2lzUHJldk9wdGlvbkRpc2FibGVkfVxuICAgICAgICAgIGlzQ2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgIGlzRGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgIGp1c3RpZmllZD17anVzdGlmaWVkfVxuICAgICAgICAvPlxuICAgICAgKTtcblxuICAgICAgLy8gd2Ugd2FudCB0byBzaG93IGFjdGl2ZSBkaXZpZGVycyBpbiBjaGVja2VkIG9wdGlvblxuICAgICAgLy8gaW4gb3JkZXIgdG8gYXBwbHkgc3VidGhlbWVzXG4gICAgICBjb25zdCBpc0ZpcnN0T3B0aW9uID0gaW5kZXggPT09IDA7XG4gICAgICBjb25zdCBpc0xhc3RPcHRpb24gPSBpbmRleCA9PT0gb3B0aW9ucy5sZW5ndGggLSAxO1xuXG4gICAgICAvLyB3ZSBoaWRlIGRpdmlkZXIgZm9yIGxhc3Qgb3B0aW9uIGFuZCBhbHdheXMgc2hvdyBmb3IgY2hlY2tlZCBvcHRpb25cbiAgICAgIGNvbnN0IGlzUmlnaHREaXZpZGVyID0gIWlzTGFzdE9wdGlvbiAmJiBpc0NoZWNrZWQ7XG5cbiAgICAgIC8vIHdlIGhpZGUgbGVmdCBkaXZpZGVyIGZvciBmaXJzdCBvcHRpb25cbiAgICAgIC8vIHdlIGhpZGUgZ3JheSBkaXZpZGVyIGlmIHByZXZpb3VzIG9wdGlvbiBpcyBjaGVja2VkLFxuICAgICAgLy8gYmVjYXVzZSB0aGVyZSBpcyBpc1JpZ2h0RGl2aWRlciBhbHJlYWR5IGluIHByZXZpb3VzIG9wdGlvblxuICAgICAgY29uc3QgaXNMZWZ0RGl2aWRlciA9ICFpc0ZpcnN0T3B0aW9uICYmICFpc1ByZXZPcHRpb25DaGVja2VkO1xuXG4gICAgICBjb25zdCBvcHRpb25FbG0gPSAoXG4gICAgICAgIDw+XG4gICAgICAgICAge2lzTGVmdERpdmlkZXIgJiYgZGl2aWRlckVsbX1cbiAgICAgICAgICA8U2VnbWVudGVkQ29udHJvbE9wdGlvblxuICAgICAgICAgICAgdmFsdWU9e29wdGlvblZhbHVlfVxuICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgIGNoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICAgIGlzUmVzcG9uc2l2ZT17anVzdGlmaWVkfVxuICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX1cbiAgICAgICAgICAgIHsuLi5vdGhlclByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgICAge2lzUmlnaHREaXZpZGVyICYmIGRpdmlkZXJFbG19XG4gICAgICAgIDwvPlxuICAgICAgKTtcblxuICAgICAgY29uc3Qgd3JhcHBlZE9wdGlvbkVsbSA9IHJlbmRlck9wdGlvbldyYXBwZXJcbiAgICAgICAgPyByZW5kZXJPcHRpb25XcmFwcGVyKHtcbiAgICAgICAgICAgIG9wdGlvbjogb3B0aW9uRWxtLFxuICAgICAgICAgICAgY2hlY2tlZDogaXNDaGVja2VkLFxuICAgICAgICAgICAgZGlzYWJsZWQsXG4gICAgICAgICAgICB2YWx1ZTogb3B0aW9uVmFsdWUsXG4gICAgICAgICAgfSlcbiAgICAgICAgOiBvcHRpb25FbG07XG5cbiAgICAgIHJldHVybiA8RnJhZ21lbnQga2V5PXtvcHRpb25WYWx1ZX0+e3dyYXBwZWRPcHRpb25FbG19PC9GcmFnbWVudD47XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZEdyb3VwXG4gICAgICBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiXG4gICAgICBpc0xhYmVsSGlkZGVuPXtpc0xhYmVsSGlkZGVufVxuICAgICAgey4uLnJlc3R9XG4gICAgPlxuICAgICAgPFN0eWxlZENvbnRhaW5lciBqdXN0aWZpZWQ9e2p1c3RpZmllZH0gb3B0aW9ucz17b3B0aW9uc30+XG4gICAgICAgIHtvcHRpb25FbG1zfVxuICAgICAgPC9TdHlsZWRDb250YWluZXI+XG4gICAgPC9Gb3JtRmllbGRHcm91cD5cbiAgKTtcbn1cblxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBb0V3QiJ9 */");function SegmentedControl({options,value,justified,size="m",onChange,isLabelHidden=!0,renderOptionWrapper,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,isPrevOptionChecked=options[index-1]?.value===value,isPrevOptionDisabled=options[index-1]?.disabled,dividerElm=_react.default.createElement(StyledDivider,{isPrevOptionChecked:isPrevOptionChecked,isPrevOptionDisabled:isPrevOptionDisabled,isChecked:isChecked,isDisabled:disabled,justified:justified}),isRightDivider=index!==options.length-1&&isChecked,optionElm=_react.default.createElement(_react.default.Fragment,null,0!==index&&!isPrevOptionChecked&&dividerElm,_react.default.createElement(_SegmentedControlOption.SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}),isRightDivider&&dividerElm),wrappedOptionElm=renderOptionWrapper?renderOptionWrapper({option:optionElm,checked:isChecked,disabled,value:optionValue}):optionElm;return _react.default.createElement(_react.Fragment,{key:optionValue},wrappedOptionElm)});return _react.default.createElement(_FormFieldGroup.FormFieldGroup,{"data-ds-id":"SegmentedControl",isLabelHidden:isLabelHidden,...rest},_react.default.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControl",{enumerable:!0,get:function(){return SegmentedControl}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),_FormFieldGroup=require("../FormFieldGroup/FormFieldGroup"),_SegmentedControlOption=require("./SegmentedControlOption"),StyledDivider=(0,_styled.default)("div",{target:"e1yfjg690",label:"StyledDivider"})(({theme,isChecked,isDisabled,isPrevOptionChecked,isPrevOptionDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,otherStyles={backgroundColor:theme.values.color.background.primary.default,...(isChecked||isPrevOptionChecked)&&{borderColor:theme.values.color.border.accent.default},...isDisabled&&isPrevOptionDisabled&&{opacity:theme.variables.opacity.disabled}},borderRightStyle={borderRight:border,...otherStyles};return justified?{[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{...borderRightStyle},[`@media (max-width: ${_breakpointsjson.default.m.value}px)`]:{borderBottom:border,...otherStyles}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcbmltcG9ydCB0eXBlIHsgU2VnbWVudGVkQ29udHJvbFByb3BzIH0gZnJvbSBcIi4vLXR5cGVzXCI7XG5pbXBvcnQgeyBGb3JtRmllbGRHcm91cCB9IGZyb20gXCIuLi9Gb3JtRmllbGRHcm91cC9Gb3JtRmllbGRHcm91cFwiO1xuaW1wb3J0IHsgU2VnbWVudGVkQ29udHJvbE9wdGlvbiB9IGZyb20gXCIuL1NlZ21lbnRlZENvbnRyb2xPcHRpb25cIjtcblxuZXhwb3J0IHR5cGUgeyBTZWdtZW50ZWRDb250cm9sUHJvcHMgfTtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgLi4uYm9yZGVyUmlnaHRTdHlsZSxcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiBtb2JpbGVcbiAgICAgIFtgQG1lZGlhIChtYXgtd2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4ub3RoZXJTdHlsZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbnR5cGUgU3R5bGVkQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBTZWdtZW50ZWRDb250cm9sUHJvcHMsXG4gIFwianVzdGlmaWVkXCIgfCBcIm9wdGlvbnNcIlxuPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxTdHlsZWRDb250YWluZXJQcm9wcz4oXG4gICh7IGp1c3RpZmllZCwgb3B0aW9ucyB9KSA9PiB7XG4gICAgY29uc3QgYmFzZVN0eWxlID0ge1xuICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgfTtcblxuICAgIGlmICghanVzdGlmaWVkKSB7XG4gICAgICByZXR1cm4gYmFzZVN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5iYXNlU3R5bGUsXG4gICAgICBmbGV4RGlyZWN0aW9uOiBcImNvbHVtblwiLFxuXG4gICAgICBcIiYgPiAqXCI6IHtcbiAgICAgICAgZmxleDogYDEgMSAkezEwMCAvIG9wdGlvbnMubGVuZ3RofSVgLFxuICAgICAgfSxcblxuICAgICAgW2AmID4gJHtTdHlsZWREaXZpZGVyfWBdOiB7XG4gICAgICAgIGZsZXg6IFwiMCAwIGF1dG9cIixcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICByZW5kZXJPcHRpb25XcmFwcGVyLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBpc1NpbmdsZU9wdGlvbiA9IG9wdGlvbnMubGVuZ3RoID09PSAxO1xuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBjb25zdCB0YXJnZXQgPSBldnQudGFyZ2V0IGFzIEhUTUxJbnB1dEVsZW1lbnQ7XG4gICAgaWYgKGlzU2luZ2xlT3B0aW9uKSB7XG4gICAgICBvbkNoYW5nZSh0YXJnZXQuY2hlY2tlZCA/IHRhcmdldC52YWx1ZSA6IFwiXCIpO1xuICAgIH0gZWxzZSB7XG4gICAgICBvbkNoYW5nZSh0YXJnZXQudmFsdWUpO1xuICAgIH1cbiAgfTtcblxuICBjb25zdCBvcHRpb25FbG1zID0gb3B0aW9ucy5tYXAoXG4gICAgKHsgdmFsdWU6IG9wdGlvblZhbHVlLCBkaXNhYmxlZCwgLi4ub3RoZXJQcm9wcyB9LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3QgaXNDaGVja2VkID0gdmFsdWUgPT09IG9wdGlvblZhbHVlO1xuICAgICAgY29uc3QgaXNQcmV2T3B0aW9uQ2hlY2tlZCA9IG9wdGlvbnNbaW5kZXggLSAxXT8udmFsdWUgPT09IHZhbHVlO1xuICAgICAgY29uc3QgaXNQcmV2T3B0aW9uRGlzYWJsZWQgPSBvcHRpb25zW2luZGV4IC0gMV0/LmRpc2FibGVkO1xuICAgICAgY29uc3QgZGl2aWRlckVsbSA9IChcbiAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICBpc1ByZXZPcHRpb25DaGVja2VkPXtpc1ByZXZPcHRpb25DaGVja2VkfVxuICAgICAgICAgIGlzUHJldk9wdGlvbkRpc2FibGVkPXtpc1ByZXZPcHRpb25EaXNhYmxlZH1cbiAgICAgICAgICBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICBpc0Rpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICBqdXN0aWZpZWQ9e2p1c3RpZmllZH1cbiAgICAgICAgLz5cbiAgICAgICk7XG5cbiAgICAgIC8vIHdlIHdhbnQgdG8gc2hvdyBhY3RpdmUgZGl2aWRlcnMgaW4gY2hlY2tlZCBvcHRpb25cbiAgICAgIC8vIGluIG9yZGVyIHRvIGFwcGx5IHN1YnRoZW1lc1xuICAgICAgY29uc3QgaXNGaXJzdE9wdGlvbiA9IGluZGV4ID09PSAwO1xuICAgICAgY29uc3QgaXNMYXN0T3B0aW9uID0gaW5kZXggPT09IG9wdGlvbnMubGVuZ3RoIC0gMTtcblxuICAgICAgLy8gd2UgaGlkZSBkaXZpZGVyIGZvciBsYXN0IG9wdGlvbiBhbmQgYWx3YXlzIHNob3cgZm9yIGNoZWNrZWQgb3B0aW9uXG4gICAgICBjb25zdCBpc1JpZ2h0RGl2aWRlciA9ICFpc0xhc3RPcHRpb24gJiYgaXNDaGVja2VkO1xuXG4gICAgICAvLyB3ZSBoaWRlIGxlZnQgZGl2aWRlciBmb3IgZmlyc3Qgb3B0aW9uXG4gICAgICAvLyB3ZSBoaWRlIGdyYXkgZGl2aWRlciBpZiBwcmV2aW91cyBvcHRpb24gaXMgY2hlY2tlZCxcbiAgICAgIC8vIGJlY2F1c2UgdGhlcmUgaXMgaXNSaWdodERpdmlkZXIgYWxyZWFkeSBpbiBwcmV2aW91cyBvcHRpb25cbiAgICAgIGNvbnN0IGlzTGVmdERpdmlkZXIgPSAhaXNGaXJzdE9wdGlvbiAmJiAhaXNQcmV2T3B0aW9uQ2hlY2tlZDtcblxuICAgICAgY29uc3Qgb3B0aW9uRWxtID0gKFxuICAgICAgICA8PlxuICAgICAgICAgIHtpc0xlZnREaXZpZGVyICYmIGRpdmlkZXJFbG19XG4gICAgICAgICAgPFNlZ21lbnRlZENvbnRyb2xPcHRpb25cbiAgICAgICAgICAgIHZhbHVlPXtvcHRpb25WYWx1ZX1cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBjaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc1Jlc3BvbnNpdmU9e2p1c3RpZmllZH1cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGlucHV0VHlwZT17aXNTaW5nbGVPcHRpb24gPyBcImNoZWNrYm94XCIgOiBcInJhZGlvXCJ9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgICB7aXNSaWdodERpdmlkZXIgJiYgZGl2aWRlckVsbX1cbiAgICAgICAgPC8+XG4gICAgICApO1xuXG4gICAgICBjb25zdCB3cmFwcGVkT3B0aW9uRWxtID0gcmVuZGVyT3B0aW9uV3JhcHBlclxuICAgICAgICA/IHJlbmRlck9wdGlvbldyYXBwZXIoe1xuICAgICAgICAgICAgb3B0aW9uOiBvcHRpb25FbG0sXG4gICAgICAgICAgICBjaGVja2VkOiBpc0NoZWNrZWQsXG4gICAgICAgICAgICBkaXNhYmxlZCxcbiAgICAgICAgICAgIHZhbHVlOiBvcHRpb25WYWx1ZSxcbiAgICAgICAgICB9KVxuICAgICAgICA6IG9wdGlvbkVsbTtcblxuICAgICAgcmV0dXJuIDxGcmFnbWVudCBrZXk9e29wdGlvblZhbHVlfT57d3JhcHBlZE9wdGlvbkVsbX08L0ZyYWdtZW50PjtcbiAgICB9XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkR3JvdXBcbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRDb250cm9sXCJcbiAgICAgIGlzTGFiZWxIaWRkZW49e2lzTGFiZWxIaWRkZW59XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZEdyb3VwPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFrQnNCIn0= */"),StyledContainer=(0,_styled.default)("div",{target:"e1yfjg691",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcbmltcG9ydCB0eXBlIHsgU2VnbWVudGVkQ29udHJvbFByb3BzIH0gZnJvbSBcIi4vLXR5cGVzXCI7XG5pbXBvcnQgeyBGb3JtRmllbGRHcm91cCB9IGZyb20gXCIuLi9Gb3JtRmllbGRHcm91cC9Gb3JtRmllbGRHcm91cFwiO1xuaW1wb3J0IHsgU2VnbWVudGVkQ29udHJvbE9wdGlvbiB9IGZyb20gXCIuL1NlZ21lbnRlZENvbnRyb2xPcHRpb25cIjtcblxuZXhwb3J0IHR5cGUgeyBTZWdtZW50ZWRDb250cm9sUHJvcHMgfTtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnQuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgLi4uYm9yZGVyUmlnaHRTdHlsZSxcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiBtb2JpbGVcbiAgICAgIFtgQG1lZGlhIChtYXgtd2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBib3JkZXJCb3R0b206IGJvcmRlcixcbiAgICAgICAgLi4ub3RoZXJTdHlsZXMsXG4gICAgICB9LFxuICAgIH07XG4gIH1cbik7XG5cbnR5cGUgU3R5bGVkQ29udGFpbmVyUHJvcHMgPSBQaWNrPFxuICBTZWdtZW50ZWRDb250cm9sUHJvcHMsXG4gIFwianVzdGlmaWVkXCIgfCBcIm9wdGlvbnNcIlxuPjtcblxuY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdjxTdHlsZWRDb250YWluZXJQcm9wcz4oXG4gICh7IGp1c3RpZmllZCwgb3B0aW9ucyB9KSA9PiB7XG4gICAgY29uc3QgYmFzZVN0eWxlID0ge1xuICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgfTtcblxuICAgIGlmICghanVzdGlmaWVkKSB7XG4gICAgICByZXR1cm4gYmFzZVN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5iYXNlU3R5bGUsXG4gICAgICBmbGV4RGlyZWN0aW9uOiBcImNvbHVtblwiLFxuXG4gICAgICBcIiYgPiAqXCI6IHtcbiAgICAgICAgZmxleDogYDEgMSAkezEwMCAvIG9wdGlvbnMubGVuZ3RofSVgLFxuICAgICAgfSxcblxuICAgICAgW2AmID4gJHtTdHlsZWREaXZpZGVyfWBdOiB7XG4gICAgICAgIGZsZXg6IFwiMCAwIGF1dG9cIixcbiAgICAgIH0sXG5cbiAgICAgIC8vIExheW91dCBvbiB0YWJsZXQgYW5kIGRlc2t0b3BcbiAgICAgIFtgQG1lZGlhIChtaW4td2lkdGg6ICR7YnJlYWtwb2ludHMubS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIGlzTGFiZWxIaWRkZW4gPSB0cnVlLFxuICByZW5kZXJPcHRpb25XcmFwcGVyLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBpc1NpbmdsZU9wdGlvbiA9IG9wdGlvbnMubGVuZ3RoID09PSAxO1xuXG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBjb25zdCB0YXJnZXQgPSBldnQudGFyZ2V0IGFzIEhUTUxJbnB1dEVsZW1lbnQ7XG4gICAgaWYgKGlzU2luZ2xlT3B0aW9uKSB7XG4gICAgICBvbkNoYW5nZSh0YXJnZXQuY2hlY2tlZCA/IHRhcmdldC52YWx1ZSA6IFwiXCIpO1xuICAgIH0gZWxzZSB7XG4gICAgICBvbkNoYW5nZSh0YXJnZXQudmFsdWUpO1xuICAgIH1cbiAgfTtcblxuICBjb25zdCBvcHRpb25FbG1zID0gb3B0aW9ucy5tYXAoXG4gICAgKHsgdmFsdWU6IG9wdGlvblZhbHVlLCBkaXNhYmxlZCwgLi4ub3RoZXJQcm9wcyB9LCBpbmRleCkgPT4ge1xuICAgICAgY29uc3QgaXNDaGVja2VkID0gdmFsdWUgPT09IG9wdGlvblZhbHVlO1xuICAgICAgY29uc3QgaXNQcmV2T3B0aW9uQ2hlY2tlZCA9IG9wdGlvbnNbaW5kZXggLSAxXT8udmFsdWUgPT09IHZhbHVlO1xuICAgICAgY29uc3QgaXNQcmV2T3B0aW9uRGlzYWJsZWQgPSBvcHRpb25zW2luZGV4IC0gMV0/LmRpc2FibGVkO1xuICAgICAgY29uc3QgZGl2aWRlckVsbSA9IChcbiAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICBpc1ByZXZPcHRpb25DaGVja2VkPXtpc1ByZXZPcHRpb25DaGVja2VkfVxuICAgICAgICAgIGlzUHJldk9wdGlvbkRpc2FibGVkPXtpc1ByZXZPcHRpb25EaXNhYmxlZH1cbiAgICAgICAgICBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICBpc0Rpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICBqdXN0aWZpZWQ9e2p1c3RpZmllZH1cbiAgICAgICAgLz5cbiAgICAgICk7XG5cbiAgICAgIC8vIHdlIHdhbnQgdG8gc2hvdyBhY3RpdmUgZGl2aWRlcnMgaW4gY2hlY2tlZCBvcHRpb25cbiAgICAgIC8vIGluIG9yZGVyIHRvIGFwcGx5IHN1YnRoZW1lc1xuICAgICAgY29uc3QgaXNGaXJzdE9wdGlvbiA9IGluZGV4ID09PSAwO1xuICAgICAgY29uc3QgaXNMYXN0T3B0aW9uID0gaW5kZXggPT09IG9wdGlvbnMubGVuZ3RoIC0gMTtcblxuICAgICAgLy8gd2UgaGlkZSBkaXZpZGVyIGZvciBsYXN0IG9wdGlvbiBhbmQgYWx3YXlzIHNob3cgZm9yIGNoZWNrZWQgb3B0aW9uXG4gICAgICBjb25zdCBpc1JpZ2h0RGl2aWRlciA9ICFpc0xhc3RPcHRpb24gJiYgaXNDaGVja2VkO1xuXG4gICAgICAvLyB3ZSBoaWRlIGxlZnQgZGl2aWRlciBmb3IgZmlyc3Qgb3B0aW9uXG4gICAgICAvLyB3ZSBoaWRlIGdyYXkgZGl2aWRlciBpZiBwcmV2aW91cyBvcHRpb24gaXMgY2hlY2tlZCxcbiAgICAgIC8vIGJlY2F1c2UgdGhlcmUgaXMgaXNSaWdodERpdmlkZXIgYWxyZWFkeSBpbiBwcmV2aW91cyBvcHRpb25cbiAgICAgIGNvbnN0IGlzTGVmdERpdmlkZXIgPSAhaXNGaXJzdE9wdGlvbiAmJiAhaXNQcmV2T3B0aW9uQ2hlY2tlZDtcblxuICAgICAgY29uc3Qgb3B0aW9uRWxtID0gKFxuICAgICAgICA8PlxuICAgICAgICAgIHtpc0xlZnREaXZpZGVyICYmIGRpdmlkZXJFbG19XG4gICAgICAgICAgPFNlZ21lbnRlZENvbnRyb2xPcHRpb25cbiAgICAgICAgICAgIHZhbHVlPXtvcHRpb25WYWx1ZX1cbiAgICAgICAgICAgIHNpemU9e3NpemV9XG4gICAgICAgICAgICBjaGVja2VkPXtpc0NoZWNrZWR9XG4gICAgICAgICAgICBpc1Jlc3BvbnNpdmU9e2p1c3RpZmllZH1cbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIGlucHV0VHlwZT17aXNTaW5nbGVPcHRpb24gPyBcImNoZWNrYm94XCIgOiBcInJhZGlvXCJ9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgICB7aXNSaWdodERpdmlkZXIgJiYgZGl2aWRlckVsbX1cbiAgICAgICAgPC8+XG4gICAgICApO1xuXG4gICAgICBjb25zdCB3cmFwcGVkT3B0aW9uRWxtID0gcmVuZGVyT3B0aW9uV3JhcHBlclxuICAgICAgICA/IHJlbmRlck9wdGlvbldyYXBwZXIoe1xuICAgICAgICAgICAgb3B0aW9uOiBvcHRpb25FbG0sXG4gICAgICAgICAgICBjaGVja2VkOiBpc0NoZWNrZWQsXG4gICAgICAgICAgICBkaXNhYmxlZCxcbiAgICAgICAgICAgIHZhbHVlOiBvcHRpb25WYWx1ZSxcbiAgICAgICAgICB9KVxuICAgICAgICA6IG9wdGlvbkVsbTtcblxuICAgICAgcmV0dXJuIDxGcmFnbWVudCBrZXk9e29wdGlvblZhbHVlfT57d3JhcHBlZE9wdGlvbkVsbX08L0ZyYWdtZW50PjtcbiAgICB9XG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybUZpZWxkR3JvdXBcbiAgICAgIGRhdGEtZHMtaWQ9XCJTZWdtZW50ZWRDb250cm9sXCJcbiAgICAgIGlzTGFiZWxIaWRkZW49e2lzTGFiZWxIaWRkZW59XG4gICAgICB7Li4ucmVzdH1cbiAgICA+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZEdyb3VwPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRXdCIn0= */");function SegmentedControl({options,value,justified,size="m",onChange,isLabelHidden=!0,renderOptionWrapper,...rest}){let isSingleOption=1===options.length,handleChange=evt=>{let target=evt.target;isSingleOption?onChange(target.checked?target.value:""):onChange(target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,isPrevOptionChecked=options[index-1]?.value===value,isPrevOptionDisabled=options[index-1]?.disabled,dividerElm=_react.default.createElement(StyledDivider,{isPrevOptionChecked:isPrevOptionChecked,isPrevOptionDisabled:isPrevOptionDisabled,isChecked:isChecked,isDisabled:disabled,justified:justified}),isRightDivider=index!==options.length-1&&isChecked,optionElm=_react.default.createElement(_react.default.Fragment,null,0!==index&&!isPrevOptionChecked&&dividerElm,_react.default.createElement(_SegmentedControlOption.SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,inputType:isSingleOption?"checkbox":"radio",onChange:handleChange,...otherProps}),isRightDivider&&dividerElm),wrappedOptionElm=renderOptionWrapper?renderOptionWrapper({option:optionElm,checked:isChecked,disabled,value:optionValue}):optionElm;return _react.default.createElement(_react.Fragment,{key:optionValue},wrappedOptionElm)});return _react.default.createElement(_FormFieldGroup.FormFieldGroup,{"data-ds-id":"SegmentedControl",isLabelHidden:isLabelHidden,...rest},_react.default.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
@@ -1,3 +1,3 @@
1
1
  import React from "react";
2
2
  import type { SegmentedControlOptionProps } from "./-types";
3
- export declare function SegmentedControlOption({ name, value, checked, label, sublabel, iconName, iconOnly, slotProps, tooltipContent, tooltipPlacement, tooltipPortalContainer, size, disabled, isResponsive, displayAsOptionWithSublabel, onChange, onClick, onBlur, onFocus, onTooltipVisibilityChange, }: SegmentedControlOptionProps): React.ReactElement;
3
+ export declare function SegmentedControlOption({ name, value, checked, label, sublabel, iconName, iconOnly, slotProps, tooltipContent, tooltipPlacement, tooltipPortalContainer, size, disabled, isResponsive, inputType, displayAsOptionWithSublabel, onChange, onClick, onBlur, onFocus, onTooltipVisibilityChange, }: SegmentedControlOptionProps): React.ReactElement;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControlOption",{enumerable:!0,get:function(){return SegmentedControlOption}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),_Text=require("../../Typography/Text/Text"),_Icon=require("../../Icon/Icon"),_ScreenReaderText=require("../../Utilities/ScreenReaderText/ScreenReaderText"),_Tooltip=require("../../Tooltip/Tooltip"),_Inline=require("../../Inline/Inline"),_mixins=require("../../../shared/mixins"),StyledInput=(0,_styled.default)("input",{target:"e1qvgn7m0",label:"StyledInput"})(({theme})=>({position:"absolute",height:1,width:1,margin:-1,overflow:"hidden",padding:0,opacity:theme.variables.opacity.hidden}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAYoB"} */"),StyledLabel=(0,_styled.default)(_Text.Text,{target:"e1qvgn7m1",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAsBoB"} */"),StyledSublabel=(0,_styled.default)(_Text.Text,{target:"e1qvgn7m2",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${_breakpointsjson.default.m.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA+BuB"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"e1qvgn7m3",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAqD4B"} */"),StyledContainer=(0,_styled.default)("label",{target:"e1qvgn7m4",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},basePaddingSize="s"===size?theme.variables.size.spacing.xs:theme.variables.size.spacing.s,basePadding=`calc(${basePaddingSize} - 1px)`,baseStyle={position:"relative",cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",padding:(()=>{if(iconOnly)return"l"===size?`calc(${theme.variables.size.spacing.m} - 1px)`:basePadding;let horizontalPadding="s"===size?theme.variables.size.spacing.m:theme.variables.size.spacing.l;return`${basePadding} ${horizontalPadding}`})(),...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.disabled},...checked&&(0,_mixins.getPressedStyles)({theme}),[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},[`&:has(${StyledInput}:focus-visible)`]:{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{...borderStyle},[`@media (max-width: ${_breakpointsjson.default.m.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkEwB"} */");function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,slotProps,tooltipContent,tooltipPlacement,tooltipPortalContainer,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus,onTooltipVisibilityChange}){let containerRef=(0,_react.useRef)(null),iconAriaLabel=iconOnly?label:void 0,iconElm=iconName?_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:iconName,size:"s","aria-label":slotProps?.icon?.ariaLabel??iconAriaLabel})):null,showIcon=!sublabel&&iconElm,labelElm=_react.default.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?_react.default.createElement(_react.default.Fragment,null,iconElm,_react.default.createElement(_ScreenReaderText.ScreenReaderText,null,label)):_react.default.createElement(_Inline.Inline,{space:"xs",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?_react.default.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled,tabIndex:-1},_react.default.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&_react.default.createElement(_Tooltip.Tooltip,{content:tooltipContent,externalTriggerRef:containerRef,onVisibilityChange:onTooltipVisibilityChange,placement:tooltipPlacement??"auto",portalContainer:tooltipPortalContainer}))}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"SegmentedControlOption",{enumerable:!0,get:function(){return SegmentedControlOption}});const _interop_require_default=require("@swc/helpers/_/_interop_require_default"),_react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_wildcard")._(require("react")),_styled=/*#__PURE__*/_interop_require_default._(require("@emotion/styled")),_breakpointsjson=/*#__PURE__*/_interop_require_default._(require("../../../web-tokens/_breakpoints.json")),_Text=require("../../Typography/Text/Text"),_Icon=require("../../Icon/Icon"),_ScreenReaderText=require("../../Utilities/ScreenReaderText/ScreenReaderText"),_Tooltip=require("../../Tooltip/Tooltip"),_Inline=require("../../Inline/Inline"),_mixins=require("../../../shared/mixins"),StyledInput=(0,_styled.default)("input",{target:"e1awjuo0",label:"StyledInput"})(({theme})=>({position:"absolute",height:1,width:1,margin:-1,overflow:"hidden",padding:0,opacity:theme.variables.opacity.hidden}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  inputType = \"radio\",\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type={inputType}\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-expanded={slotProps?.input?.ariaExpanded}\n          aria-controls={slotProps?.input?.ariaControls}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAYoB"} */"),StyledLabel=(0,_styled.default)(_Text.Text,{target:"e1awjuo1",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  inputType = \"radio\",\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type={inputType}\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-expanded={slotProps?.input?.ariaExpanded}\n          aria-controls={slotProps?.input?.ariaControls}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAsBoB"} */"),StyledSublabel=(0,_styled.default)(_Text.Text,{target:"e1awjuo2",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${_breakpointsjson.default.m.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  inputType = \"radio\",\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type={inputType}\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-expanded={slotProps?.input?.ariaExpanded}\n          aria-controls={slotProps?.input?.ariaControls}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA+BuB"} */"),StyledIconContainer=(0,_styled.default)("div",{target:"e1awjuo3",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  inputType = \"radio\",\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type={inputType}\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-expanded={slotProps?.input?.ariaExpanded}\n          aria-controls={slotProps?.input?.ariaControls}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAqD4B"} */"),StyledContainer=(0,_styled.default)("label",{target:"e1awjuo4",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},basePaddingSize="s"===size?theme.variables.size.spacing.xs:theme.variables.size.spacing.s,basePadding=`calc(${basePaddingSize} - 1px)`,baseStyle={position:"relative",cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",padding:(()=>{if(iconOnly)return"l"===size?`calc(${theme.variables.size.spacing.m} - 1px)`:basePadding;let horizontalPadding="s"===size?theme.variables.size.spacing.m:theme.variables.size.spacing.l;return`${basePadding} ${horizontalPadding}`})(),...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.disabled},...checked&&(0,_mixins.getPressedStyles)({theme}),[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},[`&:has(${StyledInput}:focus-visible)`]:{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1,"@media (-webkit-min-device-pixel-ratio:0)":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${_breakpointsjson.default.m.value}px)`]:{...borderStyle},[`@media (max-width: ${_breakpointsjson.default.m.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\nimport { getPressedStyles } from \"../../../shared/mixins\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const borderWidth = \"1px\";\n    const basePaddingSize =\n      size === \"s\"\n        ? theme.variables.size.spacing.xs\n        : theme.variables.size.spacing.s;\n    const basePadding = `calc(${basePaddingSize} - ${borderWidth})`;\n\n    const getPadding = () => {\n      if (iconOnly) {\n        return size === \"l\"\n          ? `calc(${theme.variables.size.spacing.m} - ${borderWidth})`\n          : basePadding;\n      }\n\n      const horizontalPadding =\n        size === \"s\"\n          ? theme.variables.size.spacing.m\n          : theme.variables.size.spacing.l;\n\n      return `${basePadding} ${horizontalPadding}`;\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n\n      border: `${borderWidth} solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n\n      padding: getPadding(),\n\n      ...(!checked &&\n        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n\n      ...(checked && getPressedStyles({ theme })),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      [`&:has(${StyledInput}:focus-visible)`]: {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n\n        \"@media (-webkit-min-device-pixel-ratio:0)\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.m.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.m.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  slotProps,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  inputType = \"radio\",\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const iconAriaLabel = iconOnly ? label : undefined;\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon\n        name={iconName}\n        size=\"s\"\n        aria-label={slotProps?.icon?.ariaLabel ?? iconAriaLabel}\n      />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"xs\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type={inputType}\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n          aria-expanded={slotProps?.input?.ariaExpanded}\n          aria-controls={slotProps?.input?.ariaControls}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkEwB"} */");function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,slotProps,tooltipContent,tooltipPlacement,tooltipPortalContainer,size,disabled=!1,isResponsive=!1,inputType="radio",displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus,onTooltipVisibilityChange}){let containerRef=(0,_react.useRef)(null),iconAriaLabel=iconOnly?label:void 0,iconElm=iconName?_react.default.createElement(StyledIconContainer,null,_react.default.createElement(_Icon.Icon,{name:iconName,size:"s","aria-label":slotProps?.icon?.ariaLabel??iconAriaLabel})):null,showIcon=!sublabel&&iconElm,labelElm=_react.default.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?_react.default.createElement(_react.default.Fragment,null,iconElm,_react.default.createElement(_ScreenReaderText.ScreenReaderText,null,label)):_react.default.createElement(_Inline.Inline,{space:"xs",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?_react.default.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return _react.default.createElement(_react.default.Fragment,null,_react.default.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled,tabIndex:-1},_react.default.createElement(StyledInput,{type:inputType,name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus,"aria-expanded":slotProps?.input?.ariaExpanded,"aria-controls":slotProps?.input?.ariaControls}),labelContainerElm,sublabelElm),!!tooltipContent&&_react.default.createElement(_Tooltip.Tooltip,{content:tooltipContent,externalTriggerRef:containerRef,onVisibilityChange:onTooltipVisibilityChange,placement:tooltipPlacement??"auto",portalContainer:tooltipPortalContainer}))}
@@ -0,0 +1,9 @@
1
+ import type { SegmentedControlOptionProps } from "src/components/Form/SegmentedControl/-types";
2
+ export type ToolbarToggleProps = Pick<SegmentedControlOptionProps, "label" | "name" | "iconName" | "iconOnly" | "size" | "disabled" | "tooltipContent" | "tooltipPlacement" | "tooltipPortalContainer" | "onTooltipVisibilityChange" | "onClick" | "onBlur" | "onFocus" | "slotProps"> & {
3
+ /** Whether the toggle is currently pressed/active */
4
+ checked: boolean;
5
+ /** Callback when toggled */
6
+ onChange: (checked: boolean) => void;
7
+ /** Test ID */
8
+ "data-e2e-test-id"?: string;
9
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});
@@ -0,0 +1,4 @@
1
+ import type { ReactElement } from "react";
2
+ import type { ToolbarToggleProps } from "./-types";
3
+ export type { ToolbarToggleProps };
4
+ export declare function ToolbarToggle({ label, name, iconName, iconOnly, size, checked, onChange, disabled, tooltipContent, tooltipPlacement, tooltipPortalContainer, onTooltipVisibilityChange, onClick, onBlur, onFocus, slotProps, "data-e2e-test-id": dataE2eTestId, }: ToolbarToggleProps): ReactElement;
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"ToolbarToggle",{enumerable:!0,get:function(){return ToolbarToggle}});const _react=/*#__PURE__*/require("@swc/helpers/_/_interop_require_default")._(require("react")),_SegmentedControl=require("../SegmentedControl/SegmentedControl");function ToolbarToggle({label,name,iconName,iconOnly,size="m",checked,onChange,disabled,tooltipContent,tooltipPlacement,tooltipPortalContainer,onTooltipVisibilityChange,onClick,onBlur,onFocus,slotProps,"data-e2e-test-id":dataE2eTestId}){let option={name,label,value:"on",disabled,tooltipContent,tooltipPlacement,tooltipPortalContainer,onTooltipVisibilityChange,onClick,onBlur,onFocus,slotProps,...void 0!==iconName?{iconName,iconOnly}:{}};return _react.default.createElement(_SegmentedControl.SegmentedControl,{"data-ds-id":"ToolbarToggle","data-e2e-test-id":dataE2eTestId,options:[option],value:checked?"on":"",size:size,onChange:value=>{onChange("on"===value)},label:label})}
@@ -20,6 +20,8 @@ type BaseProps = Pick<TooltipContentProps, "placement" | "portalContainer" | "ma
20
20
  disableReturnFocusToTrigger?: boolean;
21
21
  /** Render as sheet on mobile web */
22
22
  renderAsSheetOnMobile?: boolean;
23
+ /** When true, always render as a Sheet regardless of viewport size. */
24
+ forceSheetLayout?: boolean;
23
25
  /** Role for accessibility */
24
26
  role?: PopupRole;
25
27
  /** Props for configuring the sheet on mobile web */
@@ -29,5 +31,5 @@ type BaseProps = Pick<TooltipContentProps, "placement" | "portalContainer" | "ma
29
31
  };
30
32
  };
31
33
  export type BasePopoverProps = BaseProps & TooltipConditionalProps;
32
- export declare function BasePopover({ placement, content, children, contentPadding, maxWidth, externalTriggerRef, portalContainer, name, isVisible: isPopoverVisible, dismissOnOutsideClick, "data-e2e-test-id": dataE2eTestId, subTheme, defaultVerticalPlacement, onVisibilityChange, disableInitialFocus, disableReturnFocusToTrigger, renderAsSheetOnMobile, role, sheetProps, ...restContentProps }: BasePopoverProps): React.ReactElement;
34
+ export declare function BasePopover({ placement, content, children, contentPadding, maxWidth, externalTriggerRef, portalContainer, name, isVisible: isPopoverVisible, dismissOnOutsideClick, "data-e2e-test-id": dataE2eTestId, subTheme, defaultVerticalPlacement, onVisibilityChange, disableInitialFocus, disableReturnFocusToTrigger, renderAsSheetOnMobile, forceSheetLayout, role, sheetProps, ...restContentProps }: BasePopoverProps): React.ReactElement;
33
35
  export {};