@amboss/design-system 1.16.2 → 1.16.3

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.
@@ -1 +1 @@
1
- {"version":3,"file":"SegmentedControl.js","sources":["../../../../../../src/components/Form/SegmentedControl/SegmentedControl.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { SegmentedControlOption } from \"./SegmentedControlOption\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\n\nexport type SegmentedControlOption = {\n name: string;\n label: string;\n value: string;\n sublabel?: string;\n displayAsOptionWithSublabel?: boolean;\n onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n};\n\nexport type SegmentedControlProps = {\n /**\n * Meta data for options\n * @param name - Name for radio input\n * @param label - Label for display\n * @param value - Value for radio input\n * @param sublabel - Sublabel displayed below label (Optional)\n * @param displayAsOptionWithSublabel - Set this to true if no sublabel is available, but option is displayed as one with sublabel\n */\n options: SegmentedControlOption[];\n /** Current selected value */\n value: string;\n /** Justified layout, with equal size segments spanning to container width */\n justified?: boolean;\n /** Segment size, not applicable on mobile breakpoint */\n size?: \"s\" | \"m\" | \"l\";\n onChange: (value: string) => void;\n} & FormFieldProps;\n\ntype StyledDividerProps = {\n isChecked: boolean;\n} & Pick<SegmentedControlProps, \"justified\">;\n\nconst StyledDivider = styled.div<StyledDividerProps>(\n ({ theme, isChecked, justified }) => {\n const border = `1px solid ${theme.values.color.border.secondary.default}`;\n const baseStyles = {\n backgroundColor: theme.values.color.background.primary.default,\n };\n const checkedStyle = isChecked && {\n borderColor: theme.values.color.border.accentSubtle.default,\n };\n\n const borderRightStyle = {\n borderRight: border,\n ...baseStyles,\n ...checkedStyle,\n };\n\n if (!justified) {\n return borderRightStyle;\n }\n\n return {\n // Layout on tablet and desktop\n [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n ...borderRightStyle,\n },\n\n // Layout on mobile\n [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n borderBottom: border,\n ...baseStyles,\n ...checkedStyle,\n },\n };\n }\n);\n\ntype StyledContainerProps = Pick<\n SegmentedControlProps,\n \"justified\" | \"options\"\n>;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n ({ justified, options }) => {\n const baseStyle = {\n display: \"flex\",\n };\n\n if (!justified) {\n return baseStyle;\n }\n\n return {\n ...baseStyle,\n flexDirection: \"column\",\n\n \"& > *\": {\n flex: `1 1 ${100 / options.length}%`,\n },\n\n [`& > ${StyledDivider}`]: {\n flex: \"0 0 auto\",\n },\n\n // Layout on tablet and desktop\n [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n flexDirection: \"row\",\n },\n };\n }\n);\n\nexport function SegmentedControl({\n options,\n value,\n disabled,\n justified,\n size = \"m\",\n onChange,\n ...rest\n}: SegmentedControlProps): React.ReactElement {\n const handleChange: React.FormEventHandler<HTMLInputElement> = (evt) => {\n onChange((evt.target as HTMLInputElement).value);\n };\n\n const optionElms = options.map(\n ({ value: optionValue, ...otherProps }, index) => {\n const isChecked = value === optionValue;\n const dividerElm =\n index !== 0 ? (\n <StyledDivider isChecked={isChecked} justified={justified} />\n ) : null;\n\n return (\n <React.Fragment key={optionValue}>\n {dividerElm}\n <SegmentedControlOption\n value={optionValue}\n size={size}\n checked={isChecked}\n isResponsive={justified}\n disabled={disabled}\n onChange={handleChange}\n {...otherProps}\n />\n </React.Fragment>\n );\n }\n );\n\n return (\n <FormField data-ds-id=\"SegmentedControl\" {...rest} disabled={disabled}>\n <StyledContainer justified={justified} options={options}>\n {optionElms}\n </StyledContainer>\n </FormField>\n );\n}\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":["StyledDivider","_styled","process","env","NODE_ENV","target","label","_ref","theme","isChecked","justified","border","values","color","secondary","default","baseStyles","backgroundColor","background","primary","checkedStyle","borderColor","accentSubtle","borderRightStyle","borderRight","breakpoints","medium","value","borderBottom","StyledContainer","_ref2","options","baseStyle","display","flexDirection","flex","length","SegmentedControl","_ref3","disabled","size","onChange","rest","handleChange","evt","optionElms","map","_ref4","index","optionValue","otherProps","dividerElm","React","createElement","Fragment","key","SegmentedControlOption","_extends","checked","isResponsive","FormField"],"mappings":"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"}
1
+ {"version":3,"file":"SegmentedControl.js","sources":["../../../../../../src/components/Form/SegmentedControl/SegmentedControl.tsx"],"sourcesContent":["/* eslint-disable react/jsx-props-no-spreading */\nimport React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { FormField, FormFieldProps } from \"../FormField/FormField\";\nimport { SegmentedControlOption } from \"./SegmentedControlOption\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport { IconName } from \"../../Icon/Icon\";\n\nexport type SegmentedControlOption = {\n name: string;\n label: string;\n value: string;\n displayAsOptionWithSublabel?: boolean;\n onClick?: (e: React.FormEvent<HTMLInputElement>) => void;\n onBlur?: (e: React.FormEvent<HTMLInputElement>) => void;\n onFocus?: (e: React.FormEvent<HTMLInputElement>) => void;\n} & (\n | {\n iconName?: never;\n sublabel?: string;\n iconOnly?: never;\n tooltipContent?: never;\n }\n | {\n iconName?: IconName;\n sublabel?: never;\n iconOnly?: boolean;\n tooltipContent?: string;\n }\n);\n\nexport type SegmentedControlProps = {\n /**\n * Meta data for options\n * @param name - Name for radio input\n * @param label - Label for display\n * @param value - Value for radio input\n * @param sublabel - Sublabel displayed below label (Optional)\n * @param iconName - Leading icon along with label (Optional)\n * @param iconOnly - Show only icon with label hidden (Optional)\n * @param tooltipContent - Additional description to be shown in Tooltip (Optional)\n * @param displayAsOptionWithSublabel - Set this to true if no sublabel is available, but option is displayed as one with sublabel\n */\n options: SegmentedControlOption[];\n /** Current selected value */\n value: string;\n /** Justified layout, with equal size segments spanning to container width */\n justified?: boolean;\n /** Segment size, not applicable on mobile breakpoint */\n size?: \"s\" | \"m\" | \"l\";\n onChange: (value: string) => void;\n} & FormFieldProps;\n\ntype StyledDividerProps = {\n isChecked: boolean;\n} & Pick<SegmentedControlProps, \"justified\">;\n\nconst StyledDivider = styled.div<StyledDividerProps>(\n ({ theme, isChecked, justified }) => {\n const border = `1px solid ${theme.values.color.border.secondary.default}`;\n const baseStyles = {\n backgroundColor: theme.values.color.background.primary.default,\n };\n const checkedStyle = isChecked && {\n borderColor: theme.values.color.border.accentSubtle.default,\n };\n\n const borderRightStyle = {\n borderRight: border,\n ...baseStyles,\n ...checkedStyle,\n };\n\n if (!justified) {\n return borderRightStyle;\n }\n\n return {\n // Layout on tablet and desktop\n [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n ...borderRightStyle,\n },\n\n // Layout on mobile\n [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n borderBottom: border,\n ...baseStyles,\n ...checkedStyle,\n },\n };\n }\n);\n\ntype StyledContainerProps = Pick<\n SegmentedControlProps,\n \"justified\" | \"options\"\n>;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n ({ justified, options }) => {\n const baseStyle = {\n display: \"flex\",\n };\n\n if (!justified) {\n return baseStyle;\n }\n\n return {\n ...baseStyle,\n flexDirection: \"column\",\n\n \"& > *\": {\n flex: `1 1 ${100 / options.length}%`,\n },\n\n [`& > ${StyledDivider}`]: {\n flex: \"0 0 auto\",\n },\n\n // Layout on tablet and desktop\n [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n flexDirection: \"row\",\n },\n };\n }\n);\n\nexport function SegmentedControl({\n options,\n value,\n disabled,\n justified,\n size = \"m\",\n onChange,\n ...rest\n}: SegmentedControlProps): React.ReactElement {\n const handleChange: React.FormEventHandler<HTMLInputElement> = (evt) => {\n onChange((evt.target as HTMLInputElement).value);\n };\n\n const optionElms = options.map(\n ({ value: optionValue, ...otherProps }, index) => {\n const isChecked = value === optionValue;\n const dividerElm =\n index !== 0 ? (\n <StyledDivider isChecked={isChecked} justified={justified} />\n ) : null;\n\n return (\n <React.Fragment key={optionValue}>\n {dividerElm}\n <SegmentedControlOption\n value={optionValue}\n size={size}\n checked={isChecked}\n isResponsive={justified}\n disabled={disabled}\n onChange={handleChange}\n {...otherProps}\n />\n </React.Fragment>\n );\n }\n );\n\n return (\n <FormField data-ds-id=\"SegmentedControl\" {...rest} disabled={disabled}>\n <StyledContainer justified={justified} options={options}>\n {optionElms}\n </StyledContainer>\n </FormField>\n );\n}\n/* eslint-enable react/jsx-props-no-spreading */\n"],"names":["StyledDivider","_styled","process","env","NODE_ENV","target","label","_ref","theme","isChecked","justified","border","values","color","secondary","default","baseStyles","backgroundColor","background","primary","checkedStyle","borderColor","accentSubtle","borderRightStyle","borderRight","breakpoints","medium","value","borderBottom","StyledContainer","_ref2","options","baseStyle","display","flexDirection","flex","length","SegmentedControl","_ref3","disabled","size","onChange","rest","handleChange","evt","optionElms","map","_ref4","index","optionValue","otherProps","dividerElm","React","createElement","Fragment","key","SegmentedControlOption","_extends","checked","isResponsive","FormField"],"mappings":"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"}
@@ -5,4 +5,4 @@ export declare type SegmentedControlOptionProps = Pick<SegmentedControlProps, "s
5
5
  isResponsive?: boolean;
6
6
  onChange?: (e: React.FormEvent<HTMLInputElement>) => void;
7
7
  };
8
- export declare function SegmentedControlOption({ name, value, checked, label, sublabel, size, disabled, isResponsive, displayAsOptionWithSublabel, onChange, onClick, onBlur, onFocus, }: SegmentedControlOptionProps): React.ReactElement;
8
+ export declare function SegmentedControlOption({ name, value, checked, label, sublabel, iconName, iconOnly, tooltipContent, size, disabled, isResponsive, displayAsOptionWithSublabel, onChange, onClick, onBlur, onFocus, }: SegmentedControlOptionProps): React.ReactElement;
@@ -1,23 +1,27 @@
1
1
  import _styled from '@emotion/styled/base';
2
- import React from 'react';
2
+ import React, { useRef } from 'react';
3
3
  import { Text } from '../../Typography/Text/Text.js';
4
4
  import breakpoints from '../../../../build-tokens/_breakpoints.json.js';
5
+ import { Icon } from '../../Icon/Icon.js';
6
+ import { ScreenReaderText } from '../../../shared/ScreenReaderText.js';
7
+ import { Tooltip } from '../../Tooltip/Tooltip.js';
8
+ import { Inline } from '../../Inline/Inline.js';
5
9
 
6
10
  const StyledInput = /*#__PURE__*/_styled("input", process.env.NODE_ENV === "production" ? {
7
- target: "e1rc9gn63"
11
+ target: "e1rc9gn64"
8
12
  } : {
9
- target: "e1rc9gn63",
13
+ target: "e1rc9gn64",
10
14
  label: "StyledInput"
11
15
  })(() => ({
12
16
  opacity: 0,
13
17
  height: 0,
14
18
  width: 0,
15
19
  position: "absolute"
16
- }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AAmBoB","file":"SegmentedControlOption.tsx","sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  whiteSpace: \"nowrap\",\n\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"displayAsOptionWithSublabel\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n\n  return (\n    <StyledContainer\n      size={size}\n      checked={checked}\n      sublabel={sublabel}\n      isResponsive={isResponsive}\n      displayAsOptionWithSublabel={displayAsOptionWithSublabel}\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      <StyledLabel size={labelSize} weight=\"bold\">\n        {label}\n      </StyledLabel>\n      {sublabelElm}\n    </StyledContainer>\n  );\n}\n"]} */");
20
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AAuBoB","file":"SegmentedControlOption.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\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>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\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=\"s\" 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 = !disabled && 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      >\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 content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"]} */");
17
21
  const StyledLabel = /*#__PURE__*/_styled(Text, process.env.NODE_ENV === "production" ? {
18
- target: "e1rc9gn62"
22
+ target: "e1rc9gn63"
19
23
  } : {
20
- target: "e1rc9gn62",
24
+ target: "e1rc9gn63",
21
25
  label: "StyledLabel"
22
26
  })(_ref => {
23
27
  let {
@@ -25,16 +29,15 @@ const StyledLabel = /*#__PURE__*/_styled(Text, process.env.NODE_ENV === "product
25
29
  size
26
30
  } = _ref;
27
31
  return {
28
- whiteSpace: "nowrap",
29
32
  ...(size === "s" && {
30
33
  lineHeight: theme.variables.size.lineHeight.button.m
31
34
  })
32
35
  };
33
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AA0BoB","file":"SegmentedControlOption.tsx","sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  whiteSpace: \"nowrap\",\n\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"displayAsOptionWithSublabel\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n\n  return (\n    <StyledContainer\n      size={size}\n      checked={checked}\n      sublabel={sublabel}\n      isResponsive={isResponsive}\n      displayAsOptionWithSublabel={displayAsOptionWithSublabel}\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      <StyledLabel size={labelSize} weight=\"bold\">\n        {label}\n      </StyledLabel>\n      {sublabelElm}\n    </StyledContainer>\n  );\n}\n"]} */");
36
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AA8BoB","file":"SegmentedControlOption.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\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>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\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=\"s\" 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 = !disabled && 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      >\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 content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"]} */");
34
37
  const StyledSublabel = /*#__PURE__*/_styled(Text, process.env.NODE_ENV === "production" ? {
35
- target: "e1rc9gn61"
38
+ target: "e1rc9gn62"
36
39
  } : {
37
- target: "e1rc9gn61",
40
+ target: "e1rc9gn62",
38
41
  label: "StyledSublabel"
39
42
  })(_ref2 => {
40
43
  let {
@@ -56,7 +59,13 @@ const StyledSublabel = /*#__PURE__*/_styled(Text, process.env.NODE_ENV === "prod
56
59
  marginLeft: theme.variables.size.spacing.m
57
60
  }
58
61
  };
59
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AAqCuB","file":"SegmentedControlOption.tsx","sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  whiteSpace: \"nowrap\",\n\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"displayAsOptionWithSublabel\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n\n  return (\n    <StyledContainer\n      size={size}\n      checked={checked}\n      sublabel={sublabel}\n      isResponsive={isResponsive}\n      displayAsOptionWithSublabel={displayAsOptionWithSublabel}\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      <StyledLabel size={labelSize} weight=\"bold\">\n        {label}\n      </StyledLabel>\n      {sublabelElm}\n    </StyledContainer>\n  );\n}\n"]} */");
62
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AAuCuB","file":"SegmentedControlOption.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\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>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\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=\"s\" 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 = !disabled && 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      >\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 content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"]} */");
63
+ const StyledIconContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
64
+ target: "e1rc9gn61"
65
+ } : {
66
+ target: "e1rc9gn61",
67
+ label: "StyledIconContainer"
68
+ })(process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AA6D4B","file":"SegmentedControlOption.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\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>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\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=\"s\" 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 = !disabled && 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      >\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 content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"]} */");
60
69
  const StyledContainer = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "production" ? {
61
70
  target: "e1rc9gn60"
62
71
  } : {
@@ -69,6 +78,7 @@ const StyledContainer = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "
69
78
  checked,
70
79
  isResponsive,
71
80
  sublabel,
81
+ iconOnly,
72
82
  displayAsOptionWithSublabel
73
83
  } = _ref3;
74
84
  const borderStyle = {
@@ -90,13 +100,16 @@ const StyledContainer = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "
90
100
  flexDirection: "column",
91
101
  justifyContent: "center",
92
102
  alignItems: "center",
93
- padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,
103
+ padding: iconOnly ? theme.variables.size.spacing.xs : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,
94
104
  border: `1px solid ${theme.values.color.border.secondary.default}`,
95
105
  borderLeftStyle: "none",
96
106
  borderRightStyle: "none",
97
107
  position: "relative",
98
108
  ...((size === "m" || size === "l") && {
99
- padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`
109
+ padding: iconOnly ? theme.variables.size.spacing.s : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`
110
+ }),
111
+ ...(iconOnly && size === "l" && {
112
+ padding: theme.variables.size.spacing.m
100
113
  }),
101
114
  ...(!checked && {
102
115
  "&:hover": {
@@ -111,7 +124,7 @@ const StyledContainer = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "
111
124
  borderColor: theme.values.color.border.accentSubtle.default
112
125
  }
113
126
  }),
114
- [`${StyledSublabel}, ${StyledLabel}`]: {
127
+ [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {
115
128
  color: theme.values.color.text.secondary.default,
116
129
  ...(checked && {
117
130
  color: theme.values.color.text.accent.default
@@ -162,7 +175,7 @@ const StyledContainer = /*#__PURE__*/_styled("label", process.env.NODE_ENV === "
162
175
  }
163
176
  }
164
177
  };
165
- }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AAoEwB","file":"SegmentedControlOption.tsx","sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  whiteSpace: \"nowrap\",\n\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"displayAsOptionWithSublabel\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n\n  return (\n    <StyledContainer\n      size={size}\n      checked={checked}\n      sublabel={sublabel}\n      isResponsive={isResponsive}\n      displayAsOptionWithSublabel={displayAsOptionWithSublabel}\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      <StyledLabel size={labelSize} weight=\"bold\">\n        {label}\n      </StyledLabel>\n      {sublabelElm}\n    </StyledContainer>\n  );\n}\n"]} */");
178
+ }, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["SegmentedControlOption.tsx"],"names":[],"mappings":"AAyEwB","file":"SegmentedControlOption.tsx","sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n  SegmentedControlOption,\n  SegmentedControlProps,\n} from \"./SegmentedControl\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\n\nexport type SegmentedControlOptionProps = Pick<\n  SegmentedControlProps,\n  \"size\" | \"disabled\"\n> &\n  SegmentedControlOption & {\n    checked: boolean | undefined;\n    isResponsive?: boolean;\n    onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n  };\n\nconst StyledInput = styled.input(() => ({\n  opacity: 0,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.button.m,\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>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n        borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\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      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked && {\n        \"&:hover\": {\n          backgroundColor: theme.values.color.background.secondary.default,\n        },\n      }),\n\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\n\n        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n        },\n      }),\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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\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.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.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.button.m,\n          borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n          borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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  tooltipContent,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\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=\"s\" 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 = !disabled && 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      >\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 content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"]} */");
166
179
  function SegmentedControlOption(_ref4) {
167
180
  let {
168
181
  name,
@@ -170,6 +183,9 @@ function SegmentedControlOption(_ref4) {
170
183
  checked = undefined,
171
184
  label = "",
172
185
  sublabel,
186
+ iconName,
187
+ iconOnly,
188
+ tooltipContent,
173
189
  size,
174
190
  disabled = false,
175
191
  isResponsive = false,
@@ -180,16 +196,43 @@ function SegmentedControlOption(_ref4) {
180
196
  onFocus
181
197
  } = _ref4;
182
198
  const labelSize = size === "l" ? "m" : "s";
199
+ const containerRef = useRef();
200
+ const iconElm = iconName ? /*#__PURE__*/React.createElement(StyledIconContainer, null, /*#__PURE__*/React.createElement(Icon, {
201
+ name: iconName,
202
+ size: "s"
203
+ })) : null;
204
+ const showIcon = !sublabel && iconElm;
205
+ const labelElm = /*#__PURE__*/React.createElement(StyledLabel, {
206
+ size: labelSize,
207
+ weight: "bold"
208
+ }, label);
209
+ let labelContainerElm = labelElm;
210
+ if (showIcon) {
211
+ if (!iconOnly) {
212
+ // label with icon
213
+ labelContainerElm = /*#__PURE__*/React.createElement(Inline, {
214
+ space: "s",
215
+ noWrap: true,
216
+ vAlignItems: "center"
217
+ }, iconElm, labelElm);
218
+ } else {
219
+ // icon with hidden label
220
+ labelContainerElm = /*#__PURE__*/React.createElement(React.Fragment, null, iconElm, /*#__PURE__*/React.createElement(ScreenReaderText, null, label));
221
+ }
222
+ }
183
223
  const sublabelElm = sublabel ? /*#__PURE__*/React.createElement(StyledSublabel, {
184
224
  size: "s",
185
225
  isResponsive: isResponsive
186
226
  }, sublabel) : null;
187
- return /*#__PURE__*/React.createElement(StyledContainer, {
227
+ const showTooltip = !disabled && tooltipContent;
228
+ return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(StyledContainer, {
188
229
  size: size,
189
230
  checked: checked,
190
231
  sublabel: sublabel,
232
+ iconOnly: iconOnly,
191
233
  isResponsive: isResponsive,
192
- displayAsOptionWithSublabel: displayAsOptionWithSublabel
234
+ displayAsOptionWithSublabel: displayAsOptionWithSublabel,
235
+ ref: containerRef
193
236
  }, /*#__PURE__*/React.createElement(StyledInput, {
194
237
  type: "radio",
195
238
  name: name,
@@ -200,10 +243,10 @@ function SegmentedControlOption(_ref4) {
200
243
  onClick: onClick,
201
244
  onBlur: onBlur,
202
245
  onFocus: onFocus
203
- }), /*#__PURE__*/React.createElement(StyledLabel, {
204
- size: labelSize,
205
- weight: "bold"
206
- }, label), sublabelElm);
246
+ }), labelContainerElm, sublabelElm), showTooltip && /*#__PURE__*/React.createElement(Tooltip, {
247
+ content: tooltipContent,
248
+ externalTriggerRef: containerRef
249
+ }));
207
250
  }
208
251
 
209
252
  export { SegmentedControlOption };
@@ -1 +1 @@
1
- {"version":3,"file":"SegmentedControlOption.js","sources":["../../../../../../src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n SegmentedControlOption,\n SegmentedControlProps,\n} from \"./SegmentedControl\";\n\nexport type SegmentedControlOptionProps = Pick<\n SegmentedControlProps,\n \"size\" | \"disabled\"\n> &\n SegmentedControlOption & {\n checked: boolean | undefined;\n isResponsive?: boolean;\n onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n };\n\nconst StyledInput = styled.input(() => ({\n opacity: 0,\n height: 0,\n width: 0,\n position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n whiteSpace: \"nowrap\",\n\n ...(size === \"s\" && {\n lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n lineHeight: theme.variables.size.lineHeight.button.m,\n textAlign: \"right\",\n marginLeft: theme.variables.size.spacing.m,\n },\n };\n }\n);\n\ntype StyledContainerProps = Pick<\n SegmentedControlOptionProps,\n | \"size\"\n | \"checked\"\n | \"isResponsive\"\n | \"sublabel\"\n | \"displayAsOptionWithSublabel\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n ({\n theme,\n size,\n checked,\n isResponsive,\n sublabel,\n displayAsOptionWithSublabel,\n }) => {\n const borderStyle = {\n \"&:first-of-type\": {\n borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n borderLeftStyle: \"solid\" as const,\n },\n\n \"&:last-of-type\": {\n borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n borderRightStyle: \"solid\" as const,\n },\n };\n\n const baseStyle = {\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 padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n border: `1px solid ${theme.values.color.border.secondary.default}`,\n borderLeftStyle: \"none\" as const,\n borderRightStyle: \"none\" as const,\n position: \"relative\" as const,\n\n ...((size === \"m\" || size === \"l\") && {\n padding: `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n }),\n\n ...(!checked && {\n \"&:hover\": {\n backgroundColor: theme.values.color.background.secondary.default,\n },\n }),\n\n ...(checked && {\n backgroundColor: theme.values.color.background.accentSubtle.default,\n borderColor: theme.values.color.border.accentSubtle.default,\n\n // Set succeeding divider style\n \"& + div\": {\n borderColor: theme.values.color.border.accentSubtle.default,\n },\n }),\n\n [`${StyledSublabel}, ${StyledLabel}`]: {\n color: theme.values.color.text.secondary.default,\n\n ...(checked && {\n color: theme.values.color.text.accent.default,\n }),\n },\n\n \"input:focus-visible + &\": {\n outlineWidth: \"2px\",\n outlineStyle: \"solid\",\n outlineColor: \"Highlight\",\n },\n\n \"@media (-webkit-min-device-pixel-ratio:0)\": {\n \"input: focus-visible + &\": {\n outlineColor: \"-webkit-focus-ring-color\",\n outlineStyle: \"auto\",\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.medium.value}px)`]: {\n ...borderStyle,\n },\n\n // Layout mobile\n [`@media (max-width: ${breakpoints.medium.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.button.m,\n borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n borderTopStyle: \"solid\" as const,\n },\n\n \"&:last-of-type\": {\n borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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 size,\n disabled = false,\n isResponsive = false,\n displayAsOptionWithSublabel = false,\n onChange,\n onClick,\n onBlur,\n onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n const labelSize = size === \"l\" ? \"m\" : \"s\";\n const sublabelElm = sublabel ? (\n <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n {sublabel}\n </StyledSublabel>\n ) : null;\n\n return (\n <StyledContainer\n size={size}\n checked={checked}\n sublabel={sublabel}\n isResponsive={isResponsive}\n displayAsOptionWithSublabel={displayAsOptionWithSublabel}\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 <StyledLabel size={labelSize} weight=\"bold\">\n {label}\n </StyledLabel>\n {sublabelElm}\n </StyledContainer>\n );\n}\n"],"names":["StyledInput","_styled","process","env","NODE_ENV","target","label","opacity","height","width","position","StyledLabel","Text","_ref","theme","size","whiteSpace","lineHeight","variables","button","m","StyledSublabel","_ref2","isResponsive","baseStyle","textAlign","breakpoints","medium","value","marginLeft","spacing","StyledContainer","_ref3","checked","sublabel","displayAsOptionWithSublabel","borderStyle","borderTopLeftRadius","borderRadius","borderBottomLeftRadius","borderLeftStyle","borderTopRightRadius","borderBottomRightRadius","borderRightStyle","cursor","backgroundColor","values","color","background","primary","default","display","flexDirection","justifyContent","alignItems","padding","xs","border","secondary","s","l","accentSubtle","borderColor","text","accent","outlineWidth","outlineStyle","outlineColor","borderTopStyle","borderBottomStyle","SegmentedControlOption","_ref4","name","undefined","disabled","onChange","onClick","onBlur","onFocus","labelSize","sublabelElm","React","createElement","type","weight"],"mappings":"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"}
1
+ {"version":3,"file":"SegmentedControlOption.js","sources":["../../../../../../src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { Text, TextProps } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../../build-tokens/_breakpoints.json\";\nimport type {\n SegmentedControlOption,\n SegmentedControlProps,\n} from \"./SegmentedControl\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\n\nexport type SegmentedControlOptionProps = Pick<\n SegmentedControlProps,\n \"size\" | \"disabled\"\n> &\n SegmentedControlOption & {\n checked: boolean | undefined;\n isResponsive?: boolean;\n onChange?: (e: React.FormEvent<HTMLInputElement>) => void;\n };\n\nconst StyledInput = styled.input(() => ({\n opacity: 0,\n height: 0,\n width: 0,\n position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n ...(size === \"s\" && {\n lineHeight: theme.variables.size.lineHeight.button.m,\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.medium.value}px)`]: {\n lineHeight: theme.variables.size.lineHeight.button.m,\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>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n ({\n theme,\n size,\n checked,\n isResponsive,\n sublabel,\n iconOnly,\n displayAsOptionWithSublabel,\n }) => {\n const borderStyle = {\n \"&:first-of-type\": {\n borderTopLeftRadius: theme.variables.size.borderRadius.button.m,\n borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n borderLeftStyle: \"solid\" as const,\n },\n\n \"&:last-of-type\": {\n borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\n borderRightStyle: \"solid\" as const,\n },\n };\n\n const baseStyle = {\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 padding: iconOnly\n ? theme.variables.size.spacing.xs\n : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n border: `1px solid ${theme.values.color.border.secondary.default}`,\n borderLeftStyle: \"none\" as const,\n borderRightStyle: \"none\" as const,\n position: \"relative\" as const,\n\n ...((size === \"m\" || size === \"l\") && {\n padding: iconOnly\n ? theme.variables.size.spacing.s\n : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n }),\n\n ...(iconOnly &&\n size === \"l\" && {\n padding: theme.variables.size.spacing.m,\n }),\n\n ...(!checked && {\n \"&:hover\": {\n backgroundColor: theme.values.color.background.secondary.default,\n },\n }),\n\n ...(checked && {\n backgroundColor: theme.values.color.background.accentSubtle.default,\n borderColor: theme.values.color.border.accentSubtle.default,\n\n // Set succeeding divider style\n \"& + div\": {\n borderColor: theme.values.color.border.accentSubtle.default,\n },\n }),\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 \"input:focus-visible + &\": {\n outlineWidth: \"2px\",\n outlineStyle: \"solid\",\n outlineColor: \"Highlight\",\n },\n\n \"@media (-webkit-min-device-pixel-ratio:0)\": {\n \"input: focus-visible + &\": {\n outlineColor: \"-webkit-focus-ring-color\",\n outlineStyle: \"auto\",\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.medium.value}px)`]: {\n ...borderStyle,\n },\n\n // Layout mobile\n [`@media (max-width: ${breakpoints.medium.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.button.m,\n borderTopRightRadius: theme.variables.size.borderRadius.button.m,\n borderTopStyle: \"solid\" as const,\n },\n\n \"&:last-of-type\": {\n borderBottomLeftRadius: theme.variables.size.borderRadius.button.m,\n borderBottomRightRadius: theme.variables.size.borderRadius.button.m,\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 tooltipContent,\n size,\n disabled = false,\n isResponsive = false,\n displayAsOptionWithSublabel = false,\n onChange,\n onClick,\n onBlur,\n onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n const labelSize = size === \"l\" ? \"m\" : \"s\";\n const containerRef = useRef();\n const iconElm = iconName ? (\n <StyledIconContainer>\n <Icon name={iconName} size=\"s\" />\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=\"s\" 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 = !disabled && 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 >\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 content={tooltipContent} externalTriggerRef={containerRef} />\n )}\n </>\n );\n}\n"],"names":["StyledInput","_styled","process","env","NODE_ENV","target","label","opacity","height","width","position","StyledLabel","Text","_ref","theme","size","lineHeight","variables","button","m","StyledSublabel","_ref2","isResponsive","baseStyle","textAlign","breakpoints","medium","value","marginLeft","spacing","StyledIconContainer","StyledContainer","_ref3","checked","sublabel","iconOnly","displayAsOptionWithSublabel","borderStyle","borderTopLeftRadius","borderRadius","borderBottomLeftRadius","borderLeftStyle","borderTopRightRadius","borderBottomRightRadius","borderRightStyle","cursor","backgroundColor","values","color","background","primary","default","display","flexDirection","justifyContent","alignItems","padding","xs","border","secondary","s","l","accentSubtle","borderColor","text","accent","outlineWidth","outlineStyle","outlineColor","borderTopStyle","borderBottomStyle","SegmentedControlOption","_ref4","name","undefined","iconName","tooltipContent","disabled","onChange","onClick","onBlur","onFocus","labelSize","containerRef","useRef","iconElm","React","createElement","Icon","showIcon","labelElm","weight","labelContainerElm","Inline","space","noWrap","vAlignItems","Fragment","ScreenReaderText","sublabelElm","showTooltip","ref","type","Tooltip","content","externalTriggerRef"],"mappings":"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"}