@amboss/design-system 3.8.4-react19 → 3.8.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/build/cjs/components/BinaryFeedback/BinaryFeedbackOption.js +1 -1
- package/build/cjs/components/Column/Columns.js +1 -1
- package/build/cjs/components/Form/Checkbox/Checkbox.d.ts +2 -2
- package/build/cjs/components/Form/FormFieldGroup/FormFieldGroup.js +1 -1
- package/build/cjs/components/Form/MaskedInput/MaskedInput.d.ts +1 -1
- package/build/cjs/components/Form/MaskedInput/MaskedInput.js +1 -1
- package/build/cjs/components/Form/Radio/Radio.d.ts +2 -2
- package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
- package/build/cjs/components/Form/Toggle/Toggle.d.ts +2 -2
- package/build/cjs/components/Patterns/Modal/Modal.js +3 -3
- package/build/cjs/components/Popover/Popover.d.ts +2 -2
- package/build/cjs/components/Popover/Popover.js +1 -1
- package/build/cjs/components/SegmentedProgressBar/-types.d.ts +7 -2
- package/build/cjs/components/SegmentedProgressBar/LegendPopover.d.ts +11 -0
- package/build/cjs/components/SegmentedProgressBar/LegendPopover.js +1 -0
- package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +1 -1
- package/build/cjs/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
- package/build/cjs/components/ShadowWebComponent/ShadowWebComponent.d.ts +9 -0
- package/build/cjs/components/ShadowWebComponent/ShadowWebComponent.js +1 -1
- package/build/cjs/components/TagGroup/TagGroup.js +1 -1
- package/build/cjs/components/Toggletip/BasePopover.d.ts +3 -13
- package/build/cjs/components/Toggletip/BasePopover.js +1 -1
- package/build/cjs/components/Tooltip/BaseTooltip.d.ts +2 -15
- package/build/cjs/components/Typography/Header/Header.d.ts +6 -18
- package/build/cjs/components/Typography/Header/Header.js +1 -1
- package/build/cjs/shared/flattenChildren.d.ts +10 -1
- package/build/cjs/shared/flattenChildren.js +1 -1
- package/build/cjs/web-tokens/_sizes.json +10 -0
- package/build/cjs/web-tokens/visualConfig.d.ts +3 -0
- package/build/cjs/web-tokens/visualConfig.js +1 -1
- package/build/esm/components/BinaryFeedback/BinaryFeedbackOption.js +1 -1
- package/build/esm/components/Column/Columns.js +1 -1
- package/build/esm/components/Form/Checkbox/Checkbox.d.ts +2 -2
- package/build/esm/components/Form/FormFieldGroup/FormFieldGroup.js +1 -1
- package/build/esm/components/Form/MaskedInput/MaskedInput.d.ts +1 -1
- package/build/esm/components/Form/MaskedInput/MaskedInput.js +1 -1
- package/build/esm/components/Form/Radio/Radio.d.ts +2 -2
- package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
- package/build/esm/components/Form/Toggle/Toggle.d.ts +2 -2
- package/build/esm/components/Patterns/Modal/Modal.js +3 -3
- package/build/esm/components/Popover/Popover.d.ts +2 -2
- package/build/esm/components/Popover/Popover.js +1 -1
- package/build/esm/components/SegmentedProgressBar/-types.d.ts +7 -2
- package/build/esm/components/SegmentedProgressBar/LegendPopover.d.ts +11 -0
- package/build/esm/components/SegmentedProgressBar/LegendPopover.js +1 -0
- package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.d.ts +1 -1
- package/build/esm/components/SegmentedProgressBar/SegmentedProgressBar.js +1 -1
- package/build/esm/components/ShadowWebComponent/ShadowWebComponent.d.ts +9 -0
- package/build/esm/components/ShadowWebComponent/ShadowWebComponent.js +1 -1
- package/build/esm/components/TagGroup/TagGroup.js +1 -1
- package/build/esm/components/Toggletip/BasePopover.d.ts +3 -13
- package/build/esm/components/Toggletip/BasePopover.js +1 -1
- package/build/esm/components/Tooltip/BaseTooltip.d.ts +2 -15
- package/build/esm/components/Typography/Header/Header.d.ts +6 -18
- package/build/esm/components/Typography/Header/Header.js +1 -1
- package/build/esm/shared/flattenChildren.d.ts +10 -1
- package/build/esm/shared/flattenChildren.js +1 -1
- package/build/esm/web-tokens/_sizes.json +10 -0
- package/build/esm/web-tokens/visualConfig.d.ts +3 -0
- package/build/esm/web-tokens/visualConfig.js +1 -1
- package/build/scss/_variables.scss +1 -0
- package/package.json +18 -17
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useEffect,useRef,useState,useId,isValidElement}from"react";import styled from"@emotion/styled";import{Stack}from"../../Stack/Stack";import{Text}from"../../Typography/Text/Text";import{FormErrorMessages}from"../FormErrorMessages/FormErrorMessages";import{FormLabelText}from"../FormLabelText/FormLabelText";import{flattenChildren}from"../../../shared/flattenChildren";import{ScreenReaderText}from"../../Utilities/ScreenReaderText/ScreenReaderText";import{useResponsiveStyles}from"../../../shared/mediaQueries";let StyledFieldset=styled("fieldset",{target:"e178710d0",label:"StyledFieldset"})(({isObserverDone,disabled})=>({border:0,margin:0,padding:0,visibility:isObserverDone?"visible":"hidden",...disabled&&{cursor:"not-allowed"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAmCuB"} */"),InlineChildren=styled("div",{target:"e178710d1",label:"InlineChildren"})({display:"flex",flexDirection:"row",flexWrap:"nowrap"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA+CuB"} */"),FormChildren=styled("div",{target:"e178710d2",label:"FormChildren"})(({theme,shouldLabelWrap,space})=>({...useResponsiveStyles({marginRight:[space,theme.variables.size.spacing]}),whiteSpace:shouldLabelWrap?"normal":"nowrap"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAqDqB"} */"),StyledTextContainer=styled("div",{target:"e178710d3",label:"StyledTextContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA8D4B"} */"),StyledLabelContainer=styled("div",{target:"e178710d4",label:"StyledLabelContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n  isValidElement,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(flattenChildren(children), (child) => {\n              if (child && isValidElement(child)) {\n                return (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {child}\n                  </FormChildren>\n                );\n              }\n              return child;\n            })}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) => child)\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAuE6B"} */");export function FormFieldGroup({children,label="",labelAs="div",isLabelHidden=!1,labelHint="",errorMessages=[],hint="",disabled=!1,inline=!1,space="xl","data-e2e-test-id":dataE2eTestId}){let messageId=useId(),radioGroupRef=useRef(null),[isOverflowing,setIsOverflowing]=useState(!1),[isObserverDone,setIsObserverDone]=useState(!inline),[shouldLabelWrap,setShouldLabelWrap]=useState(!1);useEffect(()=>{let observer;return inline&&"undefined"!=typeof IntersectionObserver&&radioGroupRef&&radioGroupRef.current&&(observer=new IntersectionObserver(entries=>entries.forEach(entry=>{entry.isIntersecting||(setIsOverflowing(!0),setShouldLabelWrap(!0)),setIsObserverDone(!0)}),{root:radioGroupRef.current,threshold:1}),Object.entries(radioGroupRef.current.children).forEach(radio=>{let radioElement=radio[1];observer.observe(radioElement)})),()=>{observer&&observer.disconnect()}},[inline]);let validErrorMessages=errorMessages.filter(message=>message),messagesElm=(!!validErrorMessages.length||hint)&&React.createElement(Stack,{space:"xxs",id:messageId},!!validErrorMessages.length&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(FormErrorMessages,{messages:validErrorMessages})),hint&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(Text,{size:"s",color:"tertiary"},hint))),ariaDescribedBy=messagesElm?{"aria-describedby":messageId}:{};return React.createElement(StyledFieldset,{disabled:disabled,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"FormFieldGroup",isObserverDone:isObserverDone,...ariaDescribedBy},React.createElement(ScreenReaderText,{as:"legend"},label),React.createElement(Stack,{space:"xs"},label&&!isLabelHidden&&React.createElement(StyledLabelContainer,{disabled:disabled},React.createElement(FormLabelText,{labelHint:labelHint,labelAs:labelAs},label)),inline&&!isOverflowing?React.createElement(InlineChildren,{ref:radioGroupRef},React.Children.map(flattenChildren(children),child=>child&&isValidElement(child)?React.createElement(FormChildren,{shouldLabelWrap:shouldLabelWrap,space:space},child):child)):React.Children.map(flattenChildren(children),child=>child),messagesElm))}
|
|
1
|
+
import React,{useEffect,useRef,useState,useId}from"react";import styled from"@emotion/styled";import{Stack}from"../../Stack/Stack";import{Text}from"../../Typography/Text/Text";import{FormErrorMessages}from"../FormErrorMessages/FormErrorMessages";import{FormLabelText}from"../FormLabelText/FormLabelText";import{flattenChildren}from"../../../shared/flattenChildren";import{ScreenReaderText}from"../../Utilities/ScreenReaderText/ScreenReaderText";import{useResponsiveStyles}from"../../../shared/mediaQueries";let StyledFieldset=styled("fieldset",{target:"e1qfpi550",label:"StyledFieldset"})(({isObserverDone,disabled})=>({border:0,margin:0,padding:0,visibility:isObserverDone?"visible":"hidden",...disabled&&{cursor:"not-allowed"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAkCuB"} */"),InlineChildren=styled("div",{target:"e1qfpi551",label:"InlineChildren"})({display:"flex",flexDirection:"row",flexWrap:"nowrap"},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA8CuB"} */"),FormChildren=styled("div",{target:"e1qfpi552",label:"FormChildren"})(({theme,shouldLabelWrap,space})=>({...useResponsiveStyles({marginRight:[space,theme.variables.size.spacing]}),whiteSpace:shouldLabelWrap?"normal":"nowrap"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAoDqB"} */"),StyledTextContainer=styled("div",{target:"e1qfpi553",label:"StyledTextContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AA6D4B"} */"),StyledLabelContainer=styled("div",{target:"e1qfpi554",label:"StyledLabelContainer"})(({theme,disabled})=>({...disabled&&{opacity:theme.variables.opacity.disabled,pointerEvents:"none"}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/FormFieldGroup/FormFieldGroup.tsx","sources":["src/components/Form/FormFieldGroup/FormFieldGroup.tsx"],"sourcesContent":["import React, {\n  useEffect,\n  useRef,\n  useState,\n  type ElementType,\n  useId,\n} from \"react\";\nimport styled from \"@emotion/styled\";\n\nimport { Stack } from \"../../Stack/Stack\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { FormErrorMessages } from \"../FormErrorMessages/FormErrorMessages\";\nimport { FormLabelText } from \"../FormLabelText/FormLabelText\";\nimport { flattenChildren } from \"../../../shared/flattenChildren\";\nimport type { SpaceSizes, MQ } from \"../../../types\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { useResponsiveStyles } from \"../../../shared/mediaQueries\";\n\nexport type FormFieldGroupProps = {\n  label?: string;\n  labelAs?: ElementType<any, \"div\" | \"h1\" | \"h2\" | \"h3\" | \"h4\" | \"h5\" | \"h6\">;\n  isLabelHidden?: boolean;\n  labelHint?: string;\n  children: React.ReactNode[] | React.ReactElement;\n  errorMessages?: string[];\n  hint?: string;\n  disabled?: boolean;\n  /* Display form elements inline if they can fit in container */\n  inline?: boolean;\n  /* Horizontal spacing between form elements */\n  space?: SpaceSizes | MQ<SpaceSizes>;\n  \"data-e2e-test-id\"?: string;\n};\n\nconst StyledFieldset = styled.fieldset<\n  Partial<FormFieldGroupProps> & { isObserverDone: boolean }\n>(({ isObserverDone, disabled }) => ({\n  border: 0,\n  margin: 0,\n  padding: 0,\n  visibility: isObserverDone ? \"visible\" : \"hidden\",\n  ...(disabled && {\n    cursor: \"not-allowed\",\n  }),\n}));\n\nconst InlineChildren = styled.div({\n  display: \"flex\",\n  flexDirection: \"row\",\n  flexWrap: \"nowrap\",\n});\n\nconst FormChildren = styled.div<\n  Partial<FormFieldGroupProps> & { shouldLabelWrap: boolean }\n>(({ theme, shouldLabelWrap, space }) => ({\n  ...useResponsiveStyles({\n    marginRight: [space, theme.variables.size.spacing],\n  }),\n  whiteSpace: shouldLabelWrap ? \"normal\" : \"nowrap\",\n}));\n\nconst StyledTextContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nconst StyledLabelContainer = styled.div<{ disabled: boolean }>(\n  ({ theme, disabled }) => ({\n    ...(disabled && {\n      opacity: theme.variables.opacity.disabled,\n      pointerEvents: \"none\",\n    }),\n  })\n);\n\nexport function FormFieldGroup({\n  children,\n  label = \"\",\n  labelAs = \"div\",\n  isLabelHidden = false,\n  labelHint = \"\",\n  errorMessages = [],\n  hint = \"\",\n  disabled = false,\n  inline = false,\n  space = \"xl\",\n  \"data-e2e-test-id\": dataE2eTestId,\n}: FormFieldGroupProps): React.ReactElement {\n  const messageId = useId();\n  const radioGroupRef = useRef(null);\n  const [isOverflowing, setIsOverflowing] = useState(false);\n  const [isObserverDone, setIsObserverDone] = useState(!inline);\n  const [shouldLabelWrap, setShouldLabelWrap] = useState(false);\n\n  useEffect(() => {\n    let observer: IntersectionObserver;\n    if (\n      inline &&\n      typeof IntersectionObserver !== \"undefined\" &&\n      radioGroupRef &&\n      radioGroupRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) =>\n          entries.forEach((entry) => {\n            if (!entry.isIntersecting) {\n              setIsOverflowing(true);\n              setShouldLabelWrap(true);\n            }\n            setIsObserverDone(true);\n          }),\n        {\n          root: radioGroupRef.current,\n          threshold: 1,\n        }\n      );\n\n      Object.entries(radioGroupRef.current.children).forEach((radio) => {\n        const radioElement = radio[1];\n        observer.observe(radioElement as Element);\n      });\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n    };\n  }, [inline]);\n\n  const validErrorMessages = errorMessages.filter((message) => message);\n\n  const messagesElm = (!!validErrorMessages.length || hint) && (\n    <Stack space=\"xxs\" id={messageId}>\n      {!!validErrorMessages.length && (\n        <StyledTextContainer disabled={disabled}>\n          <FormErrorMessages messages={validErrorMessages} />\n        </StyledTextContainer>\n      )}\n      {hint && (\n        <StyledTextContainer disabled={disabled}>\n          <Text size=\"s\" color=\"tertiary\">\n            {hint}\n          </Text>\n        </StyledTextContainer>\n      )}\n    </Stack>\n  );\n\n  const ariaDescribedBy = messagesElm\n    ? {\n        \"aria-describedby\": messageId,\n      }\n    : {};\n\n  /* eslint-disable react/jsx-props-no-spreading */\n  return (\n    <StyledFieldset\n      disabled={disabled}\n      data-e2e-test-id={dataE2eTestId}\n      data-ds-id=\"FormFieldGroup\"\n      isObserverDone={isObserverDone}\n      {...ariaDescribedBy}\n    >\n      <ScreenReaderText as=\"legend\">{label}</ScreenReaderText>\n      <Stack space=\"xs\">\n        {label && !isLabelHidden && (\n          <StyledLabelContainer disabled={disabled}>\n            <FormLabelText labelHint={labelHint} labelAs={labelAs}>\n              {label}\n            </FormLabelText>\n          </StyledLabelContainer>\n        )}\n        {inline && !isOverflowing ? (\n          <InlineChildren ref={radioGroupRef}>\n            {React.Children.map(\n              flattenChildren(children),\n              (child) =>\n                child && (\n                  <FormChildren shouldLabelWrap={shouldLabelWrap} space={space}>\n                    {React.cloneElement(child, {\n                      disabled: disabled || child.props.disabled,\n                    })}\n                  </FormChildren>\n                )\n            )}\n          </InlineChildren>\n        ) : (\n          React.Children.map(flattenChildren(children), (child) =>\n            React.cloneElement(child, {\n              disabled: disabled || child.props.disabled,\n            })\n          )\n        )}\n        {messagesElm}\n      </Stack>\n    </StyledFieldset>\n  );\n}\n"],"names":[],"mappings":"AAsE6B"} */");export function FormFieldGroup({children,label="",labelAs="div",isLabelHidden=!1,labelHint="",errorMessages=[],hint="",disabled=!1,inline=!1,space="xl","data-e2e-test-id":dataE2eTestId}){let messageId=useId(),radioGroupRef=useRef(null),[isOverflowing,setIsOverflowing]=useState(!1),[isObserverDone,setIsObserverDone]=useState(!inline),[shouldLabelWrap,setShouldLabelWrap]=useState(!1);useEffect(()=>{let observer;return inline&&"undefined"!=typeof IntersectionObserver&&radioGroupRef&&radioGroupRef.current&&(observer=new IntersectionObserver(entries=>entries.forEach(entry=>{entry.isIntersecting||(setIsOverflowing(!0),setShouldLabelWrap(!0)),setIsObserverDone(!0)}),{root:radioGroupRef.current,threshold:1}),Object.entries(radioGroupRef.current.children).forEach(radio=>{let radioElement=radio[1];observer.observe(radioElement)})),()=>{observer&&observer.disconnect()}},[inline]);let validErrorMessages=errorMessages.filter(message=>message),messagesElm=(!!validErrorMessages.length||hint)&&React.createElement(Stack,{space:"xxs",id:messageId},!!validErrorMessages.length&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(FormErrorMessages,{messages:validErrorMessages})),hint&&React.createElement(StyledTextContainer,{disabled:disabled},React.createElement(Text,{size:"s",color:"tertiary"},hint))),ariaDescribedBy=messagesElm?{"aria-describedby":messageId}:{};return React.createElement(StyledFieldset,{disabled:disabled,"data-e2e-test-id":dataE2eTestId,"data-ds-id":"FormFieldGroup",isObserverDone:isObserverDone,...ariaDescribedBy},React.createElement(ScreenReaderText,{as:"legend"},label),React.createElement(Stack,{space:"xs"},label&&!isLabelHidden&&React.createElement(StyledLabelContainer,{disabled:disabled},React.createElement(FormLabelText,{labelHint:labelHint,labelAs:labelAs},label)),inline&&!isOverflowing?React.createElement(InlineChildren,{ref:radioGroupRef},React.Children.map(flattenChildren(children),child=>child&&React.createElement(FormChildren,{shouldLabelWrap:shouldLabelWrap,space:space},React.cloneElement(child,{disabled:disabled||child.props.disabled})))):React.Children.map(flattenChildren(children),child=>React.cloneElement(child,{disabled:disabled||child.props.disabled})),messagesElm))}
|
|
@@ -10,4 +10,4 @@ export type MaskedInputProps = {
|
|
|
10
10
|
export declare const MaskedInput: React.ForwardRefExoticComponent<{
|
|
11
11
|
maskOptions: FactoryArg;
|
|
12
12
|
onAccept: (value: string, unmaskedValue: string, typedValue: string) => void;
|
|
13
|
-
} & Omit<InputProps, "
|
|
13
|
+
} & Omit<InputProps, "type" | "onChange" | "placeholder"> & React.RefAttributes<HTMLInputElement>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useRef,useEffect}from"react";import IMask from"imask";import{Input}from"../Input";export const MaskedInput=React.forwardRef(({maskOptions,value,onAccept,...rest},ref)=>{let internalRef=useRef(
|
|
1
|
+
import React,{useRef,useEffect}from"react";import IMask from"imask";import{Input}from"../Input";export const MaskedInput=React.forwardRef(({maskOptions,value,onAccept,...rest},ref)=>{let internalRef=useRef(),maskRef=useRef(null),inputRef=ref||internalRef;return useEffect(()=>(inputRef?.current&&(maskRef.current=IMask(inputRef.current,maskOptions)),()=>{maskRef.current&&maskRef.current.destroy()}),[inputRef]),useEffect(()=>{maskRef.current.updateOptions(maskOptions)},[maskOptions]),useEffect(()=>{let handleAccept=()=>{onAccept(maskRef.current.value,maskRef.current.unmaskedValue,maskRef.current.typedValue)};return maskRef.current.on("accept",handleAccept),()=>{maskRef.current.off("accept",handleAccept)}},[onAccept]),useEffect(()=>{void 0!==value&&(maskRef.current.value=value)},[value]),React.createElement(Input,{...rest,ref:inputRef,type:"text"})});export{IMask};
|
|
@@ -18,7 +18,7 @@ export declare const RadioRaw: React.ForwardRefExoticComponent<{
|
|
|
18
18
|
/** Display hint below the label specific for the radio */
|
|
19
19
|
labelHint?: string | React.ReactElement;
|
|
20
20
|
size?: RadioSizes;
|
|
21
|
-
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "
|
|
21
|
+
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & {
|
|
22
22
|
labelSize?: RadioSizes;
|
|
23
23
|
} & React.RefAttributes<HTMLInputElement>>;
|
|
24
24
|
export declare const Radio: React.ForwardRefExoticComponent<{
|
|
@@ -26,5 +26,5 @@ export declare const Radio: React.ForwardRefExoticComponent<{
|
|
|
26
26
|
/** Display hint below the label specific for the radio */
|
|
27
27
|
labelHint?: string | React.ReactElement;
|
|
28
28
|
size?: RadioSizes;
|
|
29
|
-
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "
|
|
29
|
+
} & Omit<FormFieldProps, "label" | "labelHint" | "hideLabel"> & Omit<React.InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & React.RefAttributes<HTMLInputElement>>;
|
|
30
30
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import React,{useRef}from"react";import styled from"@emotion/styled";import{Text}from"../../Typography/Text/Text";import breakpoints from"../../../web-tokens/_breakpoints.json";import{Icon}from"../../Icon/Icon";import{ScreenReaderText}from"../../Utilities/ScreenReaderText/ScreenReaderText";import{Tooltip}from"../../Tooltip/Tooltip";import{Inline}from"../../Inline/Inline";let StyledInput=styled("input",{target:"e18wvd9d0",label:"StyledInput"})(({theme})=>({position:"absolute",height:1,width:1,margin:-1,overflow:"hidden",padding:0,opacity:theme.variables.opacity.hidden}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const 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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=styled(Text,{target:"e18wvd9d1",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const 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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAqBoB"} */"),StyledSublabel=styled(Text,{target:"e18wvd9d2",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${breakpoints.medium.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const 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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8BuB"} */"),StyledIconContainer=styled("div",{target:"e18wvd9d3",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const 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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAoD4B"} */"),StyledContainer=styled("label",{target:"e18wvd9d4",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},baseStyle={position:"relative",cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",padding:iconOnly?theme.variables.size.spacing.xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",...("m"===size||"l"===size)&&{padding:iconOnly?theme.variables.size.spacing.s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},...iconOnly&&"l"===size&&{padding:theme.variables.size.spacing.m},...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.disabled},...checked&&{backgroundColor:theme.values.color.background.accentSubtle.default,borderColor:theme.values.color.border.accentSubtle.default},[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},"&:focus-within":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-within":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef<HTMLLabelElement>(null);\n  const 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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiEwB"} */");export function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,tooltipPlacement,tooltipPortalContainer,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus,onTooltipVisibilityChange}){let containerRef=useRef(null),iconElm=iconName?React.createElement(StyledIconContainer,null,React.createElement(Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=React.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?React.createElement(React.Fragment,null,iconElm,React.createElement(ScreenReaderText,null,label)):React.createElement(Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?React.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return React.createElement(React.Fragment,null,React.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled,tabIndex:-1},React.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&React.createElement(Tooltip,{content:tooltipContent,externalTriggerRef:containerRef,onVisibilityChange:onTooltipVisibilityChange,placement:tooltipPlacement??"auto",portalContainer:tooltipPortalContainer}))}
|
|
1
|
+
import React,{useRef}from"react";import styled from"@emotion/styled";import{Text}from"../../Typography/Text/Text";import breakpoints from"../../../web-tokens/_breakpoints.json";import{Icon}from"../../Icon/Icon";import{ScreenReaderText}from"../../Utilities/ScreenReaderText/ScreenReaderText";import{Tooltip}from"../../Tooltip/Tooltip";import{Inline}from"../../Inline/Inline";let StyledInput=styled("input",{target:"e1w23mgd0",label:"StyledInput"})(({theme})=>({position:"absolute",height:1,width:1,margin:-1,overflow:"hidden",padding:0,opacity:theme.variables.opacity.hidden}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=styled(Text,{target:"e1w23mgd1",label:"StyledLabel"})(({theme,size})=>({..."s"===size&&{lineHeight:theme.variables.size.lineHeight.xs}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAqBoB"} */"),StyledSublabel=styled(Text,{target:"e1w23mgd2",label:"StyledSublabel"})(({theme,isResponsive})=>{let baseStyle={textAlign:"center"};return isResponsive?{...baseStyle,[`@media (max-width: ${breakpoints.medium.value}px)`]:{lineHeight:theme.variables.size.lineHeight.xs,textAlign:"right",marginLeft:theme.variables.size.spacing.m}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8BuB"} */"),StyledIconContainer=styled("div",{target:"e1w23mgd3",label:"StyledIconContainer"})("/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAoD4B"} */"),StyledContainer=styled("label",{target:"e1w23mgd4",label:"StyledContainer"})(({theme,size,checked,isResponsive,sublabel,iconOnly,displayAsOptionWithSublabel,disabled})=>{let borderStyle={"&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderLeftStyle:"solid"},"&:last-of-type":{borderTopRightRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderRightStyle:"solid"}},baseStyle={position:"relative",cursor:"pointer",backgroundColor:theme.values.color.background.primary.default,display:"flex",flexDirection:"column",justifyContent:"center",alignItems:"center",padding:iconOnly?theme.variables.size.spacing.xs:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,border:`1px solid ${theme.values.color.border.secondary.default}`,borderLeftStyle:"none",borderRightStyle:"none",...("m"===size||"l"===size)&&{padding:iconOnly?theme.variables.size.spacing.s:`${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`},...iconOnly&&"l"===size&&{padding:theme.variables.size.spacing.m},...!checked&&!disabled&&{"&:hover":{backgroundColor:theme.values.color.background.secondary.default}},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.disabled},...checked&&{backgroundColor:theme.values.color.background.accentSubtle.default,borderColor:theme.values.color.border.accentSubtle.default},[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},"&:focus-within":{outlineWidth:2,outlineStyle:"solid",outlineColor:"Highlight",outlineOffset:-1},"@media (-webkit-min-device-pixel-ratio:0)":{"&:focus-within":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"solid"}}};return isResponsive?{...baseStyle,[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row",justifyContent:sublabel||displayAsOptionWithSublabel?"space-between":"center",padding:theme.variables.size.spacing.m,borderTopStyle:"none",borderBottomStyle:"none",borderLeftStyle:"solid",borderRightStyle:"solid","&:first-of-type":{borderTopLeftRadius:theme.variables.size.borderRadius.xs,borderTopRightRadius:theme.variables.size.borderRadius.xs,borderTopStyle:"solid"},"&:last-of-type":{borderBottomLeftRadius:theme.variables.size.borderRadius.xs,borderBottomRightRadius:theme.variables.size.borderRadius.xs,borderBottomStyle:"solid"}}}:{...baseStyle,...borderStyle}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/SegmentedControl/SegmentedControlOption.tsx","sources":["src/components/Form/SegmentedControl/SegmentedControlOption.tsx"],"sourcesContent":["import React, { useRef } from \"react\";\nimport styled from \"@emotion/styled\";\nimport type { TextProps } from \"../../Typography/Text/Text\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport breakpoints from \"../../../web-tokens/_breakpoints.json\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { ScreenReaderText } from \"../../Utilities/ScreenReaderText/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  position: \"absolute\",\n  height: 1,\n  width: 1,\n  margin: -1,\n  overflow: \"hidden\",\n  padding: 0,\n  opacity: theme.variables.opacity.hidden,\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.xs,\n  }),\n}));\n\ntype StyledSublabelProps = TextProps &\n  Pick<SegmentedControlOptionProps, \"isResponsive\">;\n\nconst StyledSublabel = styled(Text)<StyledSublabelProps>(\n  ({ theme, isResponsive }) => {\n    const baseStyle = {\n      textAlign: \"center\" as const,\n    };\n\n    if (!isResponsive) {\n      return baseStyle;\n    }\n\n    return {\n      ...baseStyle,\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        lineHeight: theme.variables.size.lineHeight.xs,\n        textAlign: \"right\",\n        marginLeft: theme.variables.size.spacing.m,\n      },\n    };\n  }\n);\n\nconst StyledIconContainer = styled.div();\n\ntype StyledContainerProps = Pick<\n  SegmentedControlOptionProps,\n  | \"size\"\n  | \"checked\"\n  | \"isResponsive\"\n  | \"sublabel\"\n  | \"iconOnly\"\n  | \"displayAsOptionWithSublabel\"\n  | \"disabled\"\n>;\n\nconst StyledContainer = styled.label<StyledContainerProps>(\n  ({\n    theme,\n    size,\n    checked,\n    isResponsive,\n    sublabel,\n    iconOnly,\n    displayAsOptionWithSublabel,\n    disabled,\n  }) => {\n    const borderStyle = {\n      \"&:first-of-type\": {\n        borderTopLeftRadius: theme.variables.size.borderRadius.xs,\n        borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n        borderLeftStyle: \"solid\" as const,\n      },\n\n      \"&:last-of-type\": {\n        borderTopRightRadius: theme.variables.size.borderRadius.xs,\n        borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n        borderRightStyle: \"solid\" as const,\n      },\n    };\n\n    const baseStyle = {\n      position: \"relative\" as const,\n      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      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\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        !disabled && {\n          \"&:hover\": {\n            backgroundColor: theme.values.color.background.secondary.default,\n          },\n        }),\n      ...(disabled && {\n        cursor: \"not-allowed\",\n        opacity: theme.variables.opacity.disabled,\n      }),\n      ...(checked && {\n        backgroundColor: theme.values.color.background.accentSubtle.default,\n        borderColor: theme.values.color.border.accentSubtle.default,\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      \"&:focus-within\": {\n        outlineWidth: 2,\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n        outlineOffset: -1,\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"&:focus-within\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"solid\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.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.xs,\n          borderTopRightRadius: theme.variables.size.borderRadius.xs,\n          borderTopStyle: \"solid\" as const,\n        },\n\n        \"&:last-of-type\": {\n          borderBottomLeftRadius: theme.variables.size.borderRadius.xs,\n          borderBottomRightRadius: theme.variables.size.borderRadius.xs,\n          borderBottomStyle: \"solid\" as const,\n        },\n      },\n    };\n  }\n);\n\nexport function SegmentedControlOption({\n  name,\n  value = \"\",\n  checked = undefined,\n  label = \"\",\n  sublabel,\n  iconName,\n  iconOnly,\n  tooltipContent,\n  tooltipPlacement,\n  tooltipPortalContainer,\n  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n  onTooltipVisibilityChange,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\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 = Boolean(tooltipContent);\n\n  return (\n    <>\n      <StyledContainer\n        size={size}\n        checked={checked}\n        sublabel={sublabel}\n        iconOnly={iconOnly}\n        isResponsive={isResponsive}\n        displayAsOptionWithSublabel={displayAsOptionWithSublabel}\n        ref={containerRef}\n        disabled={disabled}\n        tabIndex={-1} // Remove container from focus order so that the radio input gets focus directly\n      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip\n          content={tooltipContent}\n          externalTriggerRef={containerRef}\n          onVisibilityChange={onTooltipVisibilityChange}\n          placement={tooltipPlacement ?? \"auto\"}\n          portalContainer={tooltipPortalContainer}\n        />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiEwB"} */");export function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,tooltipPlacement,tooltipPortalContainer,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus,onTooltipVisibilityChange}){let containerRef=useRef(),iconElm=iconName?React.createElement(StyledIconContainer,null,React.createElement(Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=React.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?React.createElement(React.Fragment,null,iconElm,React.createElement(ScreenReaderText,null,label)):React.createElement(Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?React.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return React.createElement(React.Fragment,null,React.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled,tabIndex:-1},React.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&React.createElement(Tooltip,{content:tooltipContent,externalTriggerRef:containerRef,onVisibilityChange:onTooltipVisibilityChange,placement:tooltipPlacement??"auto",portalContainer:tooltipPortalContainer}))}
|
|
@@ -9,7 +9,7 @@ type ToggleRawProps = {
|
|
|
9
9
|
export declare const ToggleRaw: React.ForwardRefExoticComponent<{
|
|
10
10
|
size?: ToggleSize;
|
|
11
11
|
isHighlighted?: boolean;
|
|
12
|
-
} & Omit<React.InputHTMLAttributes<HTMLInputElement>, "
|
|
12
|
+
} & Omit<React.InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & React.RefAttributes<HTMLInputElement>>;
|
|
13
13
|
export type ToggleProps = ToggleRawProps & {
|
|
14
14
|
/** Controls label alignment with respect to toggle */
|
|
15
15
|
alignLabel?: "before" | "after";
|
|
@@ -20,7 +20,7 @@ export type ToggleProps = ToggleRawProps & {
|
|
|
20
20
|
export declare const Toggle: React.ForwardRefExoticComponent<{
|
|
21
21
|
size?: ToggleSize;
|
|
22
22
|
isHighlighted?: boolean;
|
|
23
|
-
} & Omit<React.InputHTMLAttributes<HTMLInputElement>, "
|
|
23
|
+
} & Omit<React.InputHTMLAttributes<HTMLInputElement>, "type" | "size"> & {
|
|
24
24
|
/** Controls label alignment with respect to toggle */
|
|
25
25
|
alignLabel?: "before" | "after";
|
|
26
26
|
/** Display hint below the label specific for the toggle */
|