@amboss/design-system 3.0.1 → 3.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/build/cjs/components/Card/Card.d.ts +2 -1
  2. package/build/cjs/components/Card/Card.js +1 -1
  3. package/build/cjs/components/Container/Container.d.ts +2 -1
  4. package/build/cjs/components/Container/Container.js +1 -1
  5. package/build/cjs/components/Form/Checkbox/Checkbox.js +1 -1
  6. package/build/cjs/components/Form/Combobox/Combobox.js +1 -1
  7. package/build/cjs/components/Form/Combobox/OptionsList.d.ts +3 -3
  8. package/build/cjs/components/Form/Combobox/OptionsList.js +1 -1
  9. package/build/cjs/components/Form/Combobox/StyledSelectComponents.d.ts +2 -1
  10. package/build/cjs/components/Form/Combobox/StyledSelectComponents.js +1 -1
  11. package/build/cjs/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  12. package/build/cjs/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  13. package/build/cjs/components/Form/Select/Select.d.ts +1 -1
  14. package/build/cjs/components/Form/Select/Select.js +1 -1
  15. package/build/cjs/components/Form/Select/SelectWithCustomTrigger.d.ts +3 -2
  16. package/build/cjs/components/Form/Select/SelectWithCustomTrigger.js +1 -1
  17. package/build/cjs/components/Sheet/Sheet.js +1 -1
  18. package/build/cjs/components/Tabs/Tabs.d.ts +7 -1
  19. package/build/cjs/components/Tabs/Tabs.js +1 -1
  20. package/build/cjs/components/Toggletip/BasePopover.js +1 -1
  21. package/build/cjs/components/Tooltip/utils.js +1 -1
  22. package/build/cjs/components/Typography/Text/Text.js +1 -1
  23. package/build/cjs/shared/FocusTrapWrapper.d.ts +3 -2
  24. package/build/cjs/shared/FocusTrapWrapper.js +1 -1
  25. package/build/esm/components/Card/Card.d.ts +2 -1
  26. package/build/esm/components/Card/Card.js +1 -1
  27. package/build/esm/components/Container/Container.d.ts +2 -1
  28. package/build/esm/components/Container/Container.js +1 -1
  29. package/build/esm/components/Form/Checkbox/Checkbox.js +1 -1
  30. package/build/esm/components/Form/Combobox/Combobox.js +1 -1
  31. package/build/esm/components/Form/Combobox/OptionsList.d.ts +3 -3
  32. package/build/esm/components/Form/Combobox/OptionsList.js +1 -1
  33. package/build/esm/components/Form/Combobox/StyledSelectComponents.d.ts +2 -1
  34. package/build/esm/components/Form/Combobox/StyledSelectComponents.js +1 -1
  35. package/build/esm/components/Form/SegmentedControl/SegmentedControl.js +1 -1
  36. package/build/esm/components/Form/SegmentedControl/SegmentedControlOption.js +1 -1
  37. package/build/esm/components/Form/Select/Select.d.ts +1 -1
  38. package/build/esm/components/Form/Select/Select.js +1 -1
  39. package/build/esm/components/Form/Select/SelectWithCustomTrigger.d.ts +3 -2
  40. package/build/esm/components/Form/Select/SelectWithCustomTrigger.js +1 -1
  41. package/build/esm/components/Sheet/Sheet.js +1 -1
  42. package/build/esm/components/Tabs/Tabs.d.ts +7 -1
  43. package/build/esm/components/Tabs/Tabs.js +1 -1
  44. package/build/esm/components/Toggletip/BasePopover.js +1 -1
  45. package/build/esm/components/Tooltip/utils.js +1 -1
  46. package/build/esm/components/Typography/Text/Text.js +1 -1
  47. package/build/esm/shared/FocusTrapWrapper.d.ts +3 -2
  48. package/build/esm/shared/FocusTrapWrapper.js +1 -1
  49. package/package.json +1 -2
@@ -1 +1 @@
1
- import React,{useRef,useEffect,useMemo}from"react";import styled from"@emotion/styled";import{useKeyboard}from"../../../shared/useKeyboard";import{usePopupMenu}from"../../../shared/popupMenu/usePopupMenu";import{VirtualScrollList}from"../../VirtualScrollList/VirtualScrollList";import{Text}from"../../Typography/Text/Text";import{Box}from"../../Box/Box";import{Inline}from"../../Inline/Inline";import{Icon}from"../../Icon/Icon";import{StyledDropdown,StyledOption}from"./StyledSelectComponents";import{dropdownContainerStyle}from"./constants";import{Stack}from"../../Stack/Stack";import{CheckboxRaw}from"../Checkbox/Checkbox";import{Portal}from"../../Portal/Portal";export function getOptionId(selectName,optionValue){return`${selectName}Option${optionValue}`}export function getOptionsListId(selectName){return`${selectName}OptionsList`}function scrollToItem(list,itemIndex){list[itemIndex]?.scrollIntoView?.({behavior:"smooth",block:"nearest"})}let CustomOption=/*#__PURE__*/styled(StyledOption,{target:"ehvh2ti0",label:"CustomOption"})(({theme})=>({paddingTop:0,paddingBottom:0,"& > div":{paddingTop:theme.variables.size.spacing.xs,paddingBottom:theme.variables.size.spacing.xs},"& > div *":{marginTop:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Combobox/OptionsList.tsx","sources":["src/components/Form/Combobox/OptionsList.tsx"],"sourcesContent":["import type { RefObject } from \"react\";\nimport React, { useRef, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport type { CommonSelectProps, SelectOption } from \"./Combobox\";\nimport { usePopupMenu } from \"../../../shared/popupMenu/usePopupMenu\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { StyledDropdown, StyledOption } from \"./StyledSelectComponents\";\nimport { dropdownContainerStyle } from \"./constants\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { CheckboxRaw } from \"../Checkbox/Checkbox\";\nimport { Portal } from \"../../Portal/Portal\";\n\ntype OptionsListProps = {\n  isOpen: boolean;\n  isMultiSelect?: boolean;\n  triggerRef: RefObject<HTMLInputElement>;\n  triggerWrapperRef?: RefObject<HTMLDivElement>;\n  onCloseDropdown: (noSelect?: boolean) => void;\n  selectedIndex: number;\n  onSelectedIndexChange: (index: number) => void;\n  forceChangeFakeSelect: (selectedOption: SelectOption) => void;\n  isVirtualized?: boolean;\n} & Partial<CommonSelectProps>;\n\nexport function getOptionId(selectName: string, optionValue: string): string {\n  return `${selectName}Option${optionValue}`;\n}\n\nexport function getOptionsListId(selectName: string): string {\n  return `${selectName}OptionsList`;\n}\n\nfunction scrollToItem(list: HTMLDivElement[], itemIndex: number) {\n  list[itemIndex]?.scrollIntoView?.({\n    behavior: \"smooth\",\n    block: \"nearest\",\n  });\n}\n\nconst CustomOption = styled(StyledOption)(({ theme }) => ({\n  // this is needed for using padding of checkboxes in order to use its hover state\n  paddingTop: 0,\n  paddingBottom: 0,\n  \"& > div\": {\n    paddingTop: theme.variables.size.spacing.xs,\n    paddingBottom: theme.variables.size.spacing.xs,\n  },\n  \"& > div *\": {\n    marginTop: 0,\n  },\n}));\n\nconst StyledListContainer = styled.div<Pick<OptionsListProps, \"maxHeight\">>(\n  ({ maxHeight }) => ({\n    maxHeight,\n    boxSizing: \"border-box\",\n    overflow: \"auto\",\n  })\n);\n\nexport function OptionsList({\n  isOpen,\n  isMultiSelect = false,\n  value,\n  disabled,\n  options,\n  portalContainer,\n  triggerRef,\n  triggerWrapperRef,\n  maxHeight,\n  emptyStateMessage,\n  selectedIndex,\n  optionsListWidth,\n  isVirtualized = true,\n  name,\n  onCloseDropdown,\n  onSelectedIndexChange,\n  forceChangeFakeSelect,\n}: OptionsListProps): React.ReactElement {\n  const optionsListRef = useRef(null);\n  const listContainerRef = useRef(null);\n  const listItemsRef = useRef(null);\n  const refForPositioning = triggerWrapperRef || triggerRef;\n  const activeItemIndex = useMemo(\n    () =>\n      options.findIndex((option) =>\n        isMultiSelect ? value.includes(option.value) : option.value === value\n      ),\n    [options, isMultiSelect, value]\n  );\n\n  const { menuStyle: optionsListStyle, calculateStyle } = usePopupMenu({\n    triggerRef: refForPositioning,\n    menuRef: optionsListRef,\n    isOpen,\n  });\n\n  useEffect(() => {\n    if (isOpen && listContainerRef.current && !isVirtualized) {\n      const listElm = listContainerRef.current;\n      // determine overflow\n      if (listElm.clientHeight < listElm.scrollHeight) {\n        listItemsRef.current = listElm.querySelectorAll(\"[data-list-item]\");\n      }\n    } else {\n      listItemsRef.current = null;\n    }\n  }, [isOpen, isVirtualized, listContainerRef, options, maxHeight]);\n\n  useEffect(() => {\n    if (isOpen && listItemsRef.current) {\n      scrollToItem(listItemsRef.current, activeItemIndex);\n    }\n  }, [listItemsRef, activeItemIndex, isOpen]);\n\n  useEffect(() => {\n    if (listItemsRef.current) {\n      scrollToItem(listItemsRef.current, selectedIndex);\n    }\n  }, [listItemsRef, selectedIndex]);\n\n  useKeyboard(\n    {\n      Escape: () => onCloseDropdown(true),\n      Enter: () => {\n        const preselectedOption = options[selectedIndex];\n\n        if (!preselectedOption?.disabled) {\n          if (preselectedOption) {\n            forceChangeFakeSelect(preselectedOption);\n            if (!isMultiSelect) {\n              onCloseDropdown(true);\n            }\n            return;\n          }\n          if (!isMultiSelect) {\n            onCloseDropdown();\n          }\n        }\n      },\n      ArrowUp: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex > 0) {\n          newIndex -= 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n      ArrowDown: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex < options.length - 1) {\n          newIndex += 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n    },\n    triggerRef,\n    isOpen && !disabled\n  );\n\n  const renderItem = (index: number) => {\n    const option: SelectOption = options[index];\n    // Generate unique id for the option\n    const id = getOptionId(name, option.value);\n\n    if (isMultiSelect) {\n      const isActive = value.includes(option.value);\n\n      return (\n        <CustomOption\n          role=\"option\"\n          aria-selected={isActive}\n          aria-disabled={option.disabled}\n          id={id}\n          key={option.value}\n          active={isActive}\n          disabled={option.disabled}\n          preSelected={selectedIndex === index}\n          data-list-item\n          onMouseDown={() => {\n            if (!option.disabled) {\n              forceChangeFakeSelect(option);\n            }\n          }}\n          // stop event propagation to not close modal on selection if select is within a Modal\n          onClick={(evt) => evt.stopPropagation()}\n        >\n          <CheckboxRaw\n            name=\"\"\n            disabled={option.disabled}\n            checked={isActive}\n            size=\"s\"\n            label={option.label}\n            onChange={() => null}\n            labelHint={option?.description}\n          />\n        </CustomOption>\n      );\n    }\n\n    // else render single select item\n    const isActive = value === option.value;\n    const optionText = (\n      <Stack space=\"zero\">\n        <Text color=\"primary\" size=\"m\">\n          {option.label}\n        </Text>\n        {option.description && (\n          <Text color=\"tertiary\" size=\"s\">\n            {option.description}\n          </Text>\n        )}\n      </Stack>\n    );\n\n    return (\n      <StyledOption\n        role=\"option\"\n        aria-selected={isActive}\n        aria-disabled={option.disabled}\n        id={id}\n        key={option.value}\n        active={isActive}\n        disabled={option.disabled}\n        preSelected={selectedIndex === index}\n        data-list-item\n        onMouseDown={() => {\n          if (!option.disabled) {\n            forceChangeFakeSelect(option);\n            onCloseDropdown(true);\n          }\n        }}\n      >\n        {isActive ? (\n          <Inline noWrap alignItems=\"spaceBetween\">\n            {optionText}\n            <Box space=\"zero\" tSpace=\"xxxs\">\n              <Icon name=\"check\" size=\"s\" color=\"accent\" />\n            </Box>\n          </Inline>\n        ) : (\n          optionText\n        )}\n      </StyledOption>\n    );\n  };\n\n  const listStyle = {\n    ...optionsListStyle,\n    width:\n      optionsListWidth ||\n      refForPositioning.current?.getBoundingClientRect().width,\n  };\n\n  const listElm = (\n    <StyledDropdown\n      style={listStyle}\n      ref={optionsListRef}\n      // this is to prevent known bug of Chrome when element\n      // loses focus on click on the scrollbar\n      onMouseDown={(e) => e.preventDefault()}\n      data-e2e-test-id=\"optionsList\"\n    >\n      {isVirtualized ? (\n        <VirtualScrollList\n          maxHeight={maxHeight}\n          itemHeight={36}\n          itemAmount={options.length}\n          emptyState={() => (\n            <Box space=\"xs\">\n              <Text>{emptyStateMessage}</Text>\n            </Box>\n          )}\n          containerStyle={dropdownContainerStyle}\n          itemInView={selectedIndex}\n          itemTemplate={renderItem}\n          onContentHeightChange={calculateStyle}\n        />\n      ) : (\n        <StyledListContainer\n          maxHeight={maxHeight}\n          role=\"listbox\"\n          id={getOptionsListId(name)}\n          ref={listContainerRef}\n        >\n          {options.map((_option, index) => renderItem(index))}\n        </StyledListContainer>\n      )}\n    </StyledDropdown>\n  );\n\n  if (!isOpen) {\n    return null;\n  }\n\n  return <Portal portalContainer={portalContainer}>{listElm}</Portal>;\n}\n"],"names":[],"mappings":"AA4CqB"} */"),StyledListContainer=/*#__PURE__*/styled("div",{target:"ehvh2ti1",label:"StyledListContainer"})(({maxHeight})=>({maxHeight,boxSizing:"border-box",overflow:"auto"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Combobox/OptionsList.tsx","sources":["src/components/Form/Combobox/OptionsList.tsx"],"sourcesContent":["import type { RefObject } from \"react\";\nimport React, { useRef, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport type { CommonSelectProps, SelectOption } from \"./Combobox\";\nimport { usePopupMenu } from \"../../../shared/popupMenu/usePopupMenu\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { StyledDropdown, StyledOption } from \"./StyledSelectComponents\";\nimport { dropdownContainerStyle } from \"./constants\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { CheckboxRaw } from \"../Checkbox/Checkbox\";\nimport { Portal } from \"../../Portal/Portal\";\n\ntype OptionsListProps = {\n  isOpen: boolean;\n  isMultiSelect?: boolean;\n  triggerRef: RefObject<HTMLInputElement>;\n  triggerWrapperRef?: RefObject<HTMLDivElement>;\n  onCloseDropdown: (noSelect?: boolean) => void;\n  selectedIndex: number;\n  onSelectedIndexChange: (index: number) => void;\n  forceChangeFakeSelect: (selectedOption: SelectOption) => void;\n  isVirtualized?: boolean;\n} & Partial<CommonSelectProps>;\n\nexport function getOptionId(selectName: string, optionValue: string): string {\n  return `${selectName}Option${optionValue}`;\n}\n\nexport function getOptionsListId(selectName: string): string {\n  return `${selectName}OptionsList`;\n}\n\nfunction scrollToItem(list: HTMLDivElement[], itemIndex: number) {\n  list[itemIndex]?.scrollIntoView?.({\n    behavior: \"smooth\",\n    block: \"nearest\",\n  });\n}\n\nconst CustomOption = styled(StyledOption)(({ theme }) => ({\n  // this is needed for using padding of checkboxes in order to use its hover state\n  paddingTop: 0,\n  paddingBottom: 0,\n  \"& > div\": {\n    paddingTop: theme.variables.size.spacing.xs,\n    paddingBottom: theme.variables.size.spacing.xs,\n  },\n  \"& > div *\": {\n    marginTop: 0,\n  },\n}));\n\nconst StyledListContainer = styled.div<Pick<OptionsListProps, \"maxHeight\">>(\n  ({ maxHeight }) => ({\n    maxHeight,\n    boxSizing: \"border-box\",\n    overflow: \"auto\",\n  })\n);\n\nexport function OptionsList({\n  isOpen,\n  isMultiSelect = false,\n  value,\n  disabled,\n  options,\n  portalContainer,\n  triggerRef,\n  triggerWrapperRef,\n  maxHeight,\n  emptyStateMessage,\n  selectedIndex,\n  optionsListWidth,\n  isVirtualized = true,\n  name,\n  onCloseDropdown,\n  onSelectedIndexChange,\n  forceChangeFakeSelect,\n}: OptionsListProps): React.ReactElement {\n  const optionsListRef = useRef(null);\n  const listContainerRef = useRef(null);\n  const listItemsRef = useRef(null);\n  const refForPositioning = triggerWrapperRef || triggerRef;\n  const activeItemIndex = useMemo(\n    () =>\n      options.findIndex((option) =>\n        isMultiSelect ? value.includes(option.value) : option.value === value\n      ),\n    [options, isMultiSelect, value]\n  );\n\n  const { menuStyle: optionsListStyle, calculateStyle } = usePopupMenu({\n    triggerRef: refForPositioning,\n    menuRef: optionsListRef,\n    isOpen,\n  });\n\n  useEffect(() => {\n    if (isOpen && listContainerRef.current && !isVirtualized) {\n      const listElm = listContainerRef.current;\n      // determine overflow\n      if (listElm.clientHeight < listElm.scrollHeight) {\n        listItemsRef.current = listElm.querySelectorAll(\"[data-list-item]\");\n      }\n    } else {\n      listItemsRef.current = null;\n    }\n  }, [isOpen, isVirtualized, listContainerRef, options, maxHeight]);\n\n  useEffect(() => {\n    if (isOpen && listItemsRef.current) {\n      scrollToItem(listItemsRef.current, activeItemIndex);\n    }\n  }, [listItemsRef, activeItemIndex, isOpen]);\n\n  useEffect(() => {\n    if (listItemsRef.current) {\n      scrollToItem(listItemsRef.current, selectedIndex);\n    }\n  }, [listItemsRef, selectedIndex]);\n\n  useKeyboard(\n    {\n      Escape: () => onCloseDropdown(true),\n      Enter: () => {\n        const preselectedOption = options[selectedIndex];\n\n        if (!preselectedOption?.disabled) {\n          if (preselectedOption) {\n            forceChangeFakeSelect(preselectedOption);\n            if (!isMultiSelect) {\n              onCloseDropdown(true);\n            }\n            return;\n          }\n          if (!isMultiSelect) {\n            onCloseDropdown();\n          }\n        }\n      },\n      ArrowUp: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex > 0) {\n          newIndex -= 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n      ArrowDown: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex < options.length - 1) {\n          newIndex += 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n    },\n    triggerRef,\n    isOpen && !disabled\n  );\n\n  const renderItem = (index: number) => {\n    const option: SelectOption = options[index];\n    // Generate unique id for the option\n    const id = getOptionId(name, option.value);\n\n    if (isMultiSelect) {\n      const isActive = value.includes(option.value);\n\n      return (\n        <CustomOption\n          role=\"option\"\n          aria-selected={isActive}\n          aria-disabled={option.disabled}\n          id={id}\n          key={option.value}\n          active={isActive}\n          disabled={option.disabled}\n          preSelected={selectedIndex === index}\n          data-list-item\n          onMouseDown={() => {\n            if (!option.disabled) {\n              forceChangeFakeSelect(option);\n            }\n          }}\n          // stop event propagation to not close modal on selection if select is within a Modal\n          onClick={(evt) => evt.stopPropagation()}\n        >\n          <CheckboxRaw\n            name=\"\"\n            disabled={option.disabled}\n            checked={isActive}\n            size=\"s\"\n            label={option.label}\n            onChange={() => null}\n            labelHint={option?.description}\n          />\n        </CustomOption>\n      );\n    }\n\n    // else render single select item\n    const isActive = value === option.value;\n    const optionText = (\n      <Stack space=\"zero\">\n        <Text color=\"primary\" size=\"m\">\n          {option.label}\n        </Text>\n        {option.description && (\n          <Text color=\"tertiary\" size=\"s\">\n            {option.description}\n          </Text>\n        )}\n      </Stack>\n    );\n\n    return (\n      <StyledOption\n        role=\"option\"\n        aria-selected={isActive}\n        aria-disabled={option.disabled}\n        id={id}\n        key={option.value}\n        active={isActive}\n        disabled={option.disabled}\n        preSelected={selectedIndex === index}\n        data-list-item\n        onMouseDown={() => {\n          if (!option.disabled) {\n            forceChangeFakeSelect(option);\n            onCloseDropdown(true);\n          }\n        }}\n      >\n        {isActive ? (\n          <Inline noWrap alignItems=\"spaceBetween\">\n            {optionText}\n            <Box space=\"zero\" tSpace=\"xxxs\">\n              <Icon name=\"check\" size=\"s\" color=\"accent\" />\n            </Box>\n          </Inline>\n        ) : (\n          optionText\n        )}\n      </StyledOption>\n    );\n  };\n\n  const listStyle = {\n    ...optionsListStyle,\n    width:\n      optionsListWidth ||\n      refForPositioning.current?.getBoundingClientRect().width,\n  };\n\n  const listElm = (\n    <StyledDropdown\n      style={listStyle}\n      ref={optionsListRef}\n      // this is to prevent known bug of Chrome when element\n      // loses focus on click on the scrollbar\n      onMouseDown={(e) => e.preventDefault()}\n      data-e2e-test-id=\"optionsList\"\n    >\n      {isVirtualized ? (\n        <VirtualScrollList\n          maxHeight={maxHeight}\n          itemHeight={36}\n          itemAmount={options.length}\n          emptyState={() => (\n            <Box space=\"xs\">\n              <Text>{emptyStateMessage}</Text>\n            </Box>\n          )}\n          containerStyle={dropdownContainerStyle}\n          itemInView={selectedIndex}\n          itemTemplate={renderItem}\n          onContentHeightChange={calculateStyle}\n        />\n      ) : (\n        <StyledListContainer\n          maxHeight={maxHeight}\n          role=\"listbox\"\n          id={getOptionsListId(name)}\n          ref={listContainerRef}\n        >\n          {options.map((_option, index) => renderItem(index))}\n        </StyledListContainer>\n      )}\n    </StyledDropdown>\n  );\n\n  if (!isOpen) {\n    return null;\n  }\n\n  return <Portal portalContainer={portalContainer}>{listElm}</Portal>;\n}\n"],"names":[],"mappings":"AAyD4B"} */");export function OptionsList({isOpen,isMultiSelect=!1,value,disabled,options,portalContainer,triggerRef,triggerWrapperRef,maxHeight,emptyStateMessage,selectedIndex,optionsListWidth,isVirtualized=!0,name,onCloseDropdown,onSelectedIndexChange,forceChangeFakeSelect}){let optionsListRef=useRef(null),listContainerRef=useRef(null),listItemsRef=useRef(null),refForPositioning=triggerWrapperRef||triggerRef,activeItemIndex=useMemo(()=>options.findIndex(option=>isMultiSelect?value.includes(option.value):option.value===value),[options,isMultiSelect,value]),{menuStyle:optionsListStyle,calculateStyle}=usePopupMenu({triggerRef:refForPositioning,menuRef:optionsListRef,isOpen});useEffect(()=>{if(isOpen&&listContainerRef.current&&!isVirtualized){let listElm=listContainerRef.current;listElm.clientHeight<listElm.scrollHeight&&(listItemsRef.current=listElm.querySelectorAll("[data-list-item]"))}else listItemsRef.current=null},[isOpen,isVirtualized,listContainerRef,options,maxHeight]),useEffect(()=>{isOpen&&listItemsRef.current&&scrollToItem(listItemsRef.current,activeItemIndex)},[listItemsRef,activeItemIndex,isOpen]),useEffect(()=>{listItemsRef.current&&scrollToItem(listItemsRef.current,selectedIndex)},[listItemsRef,selectedIndex]),useKeyboard({Escape:()=>onCloseDropdown(!0),Enter:()=>{let preselectedOption=options[selectedIndex];if(!preselectedOption?.disabled){if(preselectedOption){forceChangeFakeSelect(preselectedOption),isMultiSelect||onCloseDropdown(!0);return}isMultiSelect||onCloseDropdown()}},ArrowUp:()=>{let newIndex=-1===selectedIndex?activeItemIndex:selectedIndex;for(;newIndex>0&&(newIndex-=1,options[newIndex]?.disabled););options[newIndex]?.disabled||onSelectedIndexChange(newIndex)},ArrowDown:()=>{let newIndex=-1===selectedIndex?activeItemIndex:selectedIndex;for(;newIndex<options.length-1&&(newIndex+=1,options[newIndex]?.disabled););options[newIndex]?.disabled||onSelectedIndexChange(newIndex)}},triggerRef,isOpen&&!disabled);let renderItem=index=>{let option=options[index],id=getOptionId(name,option.value);if(isMultiSelect){let isActive=value.includes(option.value);return /*#__PURE__*/React.createElement(CustomOption,{role:"option","aria-selected":isActive,"aria-disabled":option.disabled,id:id,key:option.value,active:isActive,disabled:option.disabled,preSelected:selectedIndex===index,"data-list-item":!0,onMouseDown:()=>{option.disabled||forceChangeFakeSelect(option)},onClick:evt=>evt.stopPropagation()},/*#__PURE__*/React.createElement(CheckboxRaw,{name:"",disabled:option.disabled,checked:isActive,size:"s",label:option.label,onChange:()=>null,labelHint:option?.description}))}let isActive=value===option.value,optionText=/*#__PURE__*/React.createElement(Stack,{space:"zero"},/*#__PURE__*/React.createElement(Text,{color:"primary",size:"m"},option.label),option.description&&/*#__PURE__*/React.createElement(Text,{color:"tertiary",size:"s"},option.description));return /*#__PURE__*/React.createElement(StyledOption,{role:"option","aria-selected":isActive,"aria-disabled":option.disabled,id:id,key:option.value,active:isActive,disabled:option.disabled,preSelected:selectedIndex===index,"data-list-item":!0,onMouseDown:()=>{option.disabled||(forceChangeFakeSelect(option),onCloseDropdown(!0))}},isActive?/*#__PURE__*/React.createElement(Inline,{noWrap:!0,alignItems:"spaceBetween"},optionText,/*#__PURE__*/React.createElement(Box,{space:"zero",tSpace:"xxxs"},/*#__PURE__*/React.createElement(Icon,{name:"check",size:"s",color:"accent"}))):optionText)},listStyle={...optionsListStyle,width:optionsListWidth||refForPositioning.current?.getBoundingClientRect().width},listElm=/*#__PURE__*/React.createElement(StyledDropdown,{style:listStyle,ref:optionsListRef,onMouseDown:e=>e.preventDefault(),"data-e2e-test-id":"optionsList"},isVirtualized?/*#__PURE__*/React.createElement(VirtualScrollList,{maxHeight:maxHeight,itemHeight:36,itemAmount:options.length,emptyState:()=>/*#__PURE__*/React.createElement(Box,{space:"xs"},/*#__PURE__*/React.createElement(Text,null,emptyStateMessage)),containerStyle:dropdownContainerStyle,itemInView:selectedIndex,itemTemplate:renderItem,onContentHeightChange:calculateStyle}):/*#__PURE__*/React.createElement(StyledListContainer,{maxHeight:maxHeight,role:"listbox",id:getOptionsListId(name),ref:listContainerRef},options.map((_option,index)=>renderItem(index))));return isOpen?/*#__PURE__*/React.createElement(Portal,{portalContainer:portalContainer},listElm):null}
1
+ import React,{useRef,useEffect,useMemo}from"react";import styled from"@emotion/styled";import{useKeyboard}from"../../../shared/useKeyboard";import{usePopupMenu}from"../../../shared/popupMenu/usePopupMenu";import{VirtualScrollList}from"../../VirtualScrollList/VirtualScrollList";import{Text}from"../../Typography/Text/Text";import{Box}from"../../Box/Box";import{Inline}from"../../Inline/Inline";import{Icon}from"../../Icon/Icon";import{StyledDropdown,StyledOption}from"./StyledSelectComponents";import{dropdownContainerStyle}from"./constants";import{Stack}from"../../Stack/Stack";import{CheckboxRaw}from"../Checkbox/Checkbox";import{Portal}from"../../Portal/Portal";export function getOptionId(selectName,optionValue){return`${selectName}Option${optionValue}`}export function getOptionsListId(selectName){return`${selectName}OptionsList`}function scrollToItem(list,itemIndex){list[itemIndex]?.scrollIntoView?.({behavior:"smooth",block:"nearest"})}let CustomOption=/*#__PURE__*/styled(StyledOption,{target:"eknc9an0",label:"CustomOption"})(({theme})=>({paddingTop:0,paddingBottom:0,"& > div":{paddingTop:theme.variables.size.spacing.xs,paddingBottom:theme.variables.size.spacing.xs},"& > div *":{marginTop:0}}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Combobox/OptionsList.tsx","sources":["src/components/Form/Combobox/OptionsList.tsx"],"sourcesContent":["import type { RefObject } from \"react\";\nimport React, { useRef, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport type { CommonSelectProps, SelectOption } from \"./Combobox\";\nimport { usePopupMenu } from \"../../../shared/popupMenu/usePopupMenu\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { StyledDropdown, StyledOption } from \"./StyledSelectComponents\";\nimport { dropdownContainerStyle } from \"./constants\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { CheckboxRaw } from \"../Checkbox/Checkbox\";\nimport { Portal } from \"../../Portal/Portal\";\n\nexport type OptionsListProps = {\n  isOpen: boolean;\n  isMultiSelect?: boolean;\n  triggerRef: RefObject<HTMLInputElement>;\n  triggerWrapperRef?: RefObject<HTMLDivElement>;\n  onCloseDropdown: (noSelect?: boolean) => void;\n  selectedIndex: number;\n  onSelectedIndexChange: (index: number) => void;\n  forceChangeFakeSelect: (selectedOption: SelectOption) => void;\n  isVirtualized?: boolean;\n  size?: \"m\" | \"s\";\n} & Partial<CommonSelectProps>;\n\nexport function getOptionId(selectName: string, optionValue: string): string {\n  return `${selectName}Option${optionValue}`;\n}\n\nexport function getOptionsListId(selectName: string): string {\n  return `${selectName}OptionsList`;\n}\n\nfunction scrollToItem(list: HTMLDivElement[], itemIndex: number) {\n  list[itemIndex]?.scrollIntoView?.({\n    behavior: \"smooth\",\n    block: \"nearest\",\n  });\n}\n\nconst CustomOption = styled(StyledOption)(({ theme }) => ({\n  // this is needed for using padding of checkboxes in order to use its hover state\n  paddingTop: 0,\n  paddingBottom: 0,\n  \"& > div\": {\n    paddingTop: theme.variables.size.spacing.xs,\n    paddingBottom: theme.variables.size.spacing.xs,\n  },\n  \"& > div *\": {\n    marginTop: 0,\n  },\n}));\n\nconst StyledListContainer = styled.div<Pick<OptionsListProps, \"maxHeight\">>(\n  ({ maxHeight }) => ({\n    maxHeight,\n    boxSizing: \"border-box\",\n    overflow: \"auto\",\n  })\n);\n\nexport function OptionsList({\n  isOpen,\n  isMultiSelect = false,\n  value,\n  disabled,\n  options,\n  portalContainer,\n  triggerRef,\n  triggerWrapperRef,\n  maxHeight,\n  emptyStateMessage,\n  selectedIndex,\n  optionsListWidth,\n  isVirtualized = true,\n  name,\n  size = \"m\",\n  onCloseDropdown,\n  onSelectedIndexChange,\n  forceChangeFakeSelect,\n}: OptionsListProps): React.ReactElement {\n  const optionsListRef = useRef(null);\n  const listContainerRef = useRef(null);\n  const listItemsRef = useRef(null);\n  const refForPositioning = triggerWrapperRef || triggerRef;\n  const activeItemIndex = useMemo(\n    () =>\n      options.findIndex((option) =>\n        isMultiSelect ? value.includes(option.value) : option.value === value\n      ),\n    [options, isMultiSelect, value]\n  );\n\n  const { menuStyle: optionsListStyle, calculateStyle } = usePopupMenu({\n    triggerRef: refForPositioning,\n    menuRef: optionsListRef,\n    isOpen,\n  });\n\n  useEffect(() => {\n    if (\n      isOpen &&\n      listContainerRef.current &&\n      !isVirtualized &&\n      optionsListStyle.top\n    ) {\n      const listElm = listContainerRef.current;\n      // determine overflow\n      if (listElm.clientHeight < listElm.scrollHeight) {\n        listItemsRef.current = listElm.querySelectorAll(\"[data-list-item]\");\n        scrollToItem(listItemsRef.current, activeItemIndex);\n      }\n    } else {\n      listItemsRef.current = null;\n    }\n  }, [\n    isOpen,\n    isVirtualized,\n    listContainerRef,\n    options,\n    maxHeight,\n    optionsListStyle,\n    activeItemIndex,\n  ]);\n\n  useEffect(() => {\n    if (listItemsRef.current) {\n      scrollToItem(listItemsRef.current, selectedIndex);\n    }\n  }, [listItemsRef, selectedIndex]);\n\n  useKeyboard(\n    {\n      Escape: () => onCloseDropdown(true),\n      Enter: () => {\n        const preselectedOption = options[selectedIndex];\n\n        if (!preselectedOption?.disabled) {\n          if (preselectedOption) {\n            forceChangeFakeSelect(preselectedOption);\n            if (!isMultiSelect) {\n              onCloseDropdown(true);\n            }\n            return;\n          }\n          if (!isMultiSelect) {\n            onCloseDropdown();\n          }\n        }\n      },\n      ArrowUp: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex > 0) {\n          newIndex -= 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n      ArrowDown: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex < options.length - 1) {\n          newIndex += 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n    },\n    triggerRef,\n    isOpen && !disabled\n  );\n\n  const renderItem = (index: number) => {\n    const option: SelectOption = options[index];\n    // Generate unique id for the option\n    const id = getOptionId(name, option.value);\n\n    if (isMultiSelect) {\n      const isActive = value.includes(option.value);\n\n      return (\n        <CustomOption\n          role=\"option\"\n          aria-selected={isActive}\n          aria-disabled={option.disabled}\n          id={id}\n          key={option.value}\n          active={isActive}\n          disabled={option.disabled}\n          preSelected={selectedIndex === index}\n          data-list-item\n          onMouseDown={() => {\n            if (!option.disabled) {\n              forceChangeFakeSelect(option);\n            }\n          }}\n          // stop event propagation to not close modal on selection if select is within a Modal\n          onClick={(evt) => evt.stopPropagation()}\n        >\n          <CheckboxRaw\n            name=\"\"\n            disabled={option.disabled}\n            checked={isActive}\n            size=\"s\"\n            label={option.label}\n            onChange={() => null}\n            labelHint={option?.description}\n          />\n        </CustomOption>\n      );\n    }\n\n    // else render single select item\n    const isActive = value === option.value;\n    const optionText = (\n      <Stack space=\"zero\">\n        <Text color=\"primary\" size={size}>\n          {option.label}\n        </Text>\n        {option.description && (\n          <Text color=\"tertiary\" size=\"s\">\n            {option.description}\n          </Text>\n        )}\n      </Stack>\n    );\n    const checkIcon = size === \"s\" ? \"check-small\" : \"check\";\n\n    return (\n      <StyledOption\n        role=\"option\"\n        aria-selected={isActive}\n        aria-disabled={option.disabled}\n        id={id}\n        key={option.value}\n        active={isActive}\n        disabled={option.disabled}\n        preSelected={selectedIndex === index}\n        data-list-item\n        size={size}\n        onMouseDown={() => {\n          if (!option.disabled) {\n            forceChangeFakeSelect(option);\n            onCloseDropdown(true);\n          }\n        }}\n      >\n        {isActive ? (\n          <Inline noWrap alignItems=\"spaceBetween\">\n            {optionText}\n            <Box space=\"zero\" tSpace=\"xxxs\">\n              <Icon name={checkIcon} size=\"s\" color=\"accent\" />\n            </Box>\n          </Inline>\n        ) : (\n          optionText\n        )}\n      </StyledOption>\n    );\n  };\n\n  const listStyle = {\n    ...optionsListStyle,\n    width:\n      optionsListWidth ||\n      refForPositioning.current?.getBoundingClientRect().width,\n  };\n\n  const listElm = (\n    <StyledDropdown\n      style={listStyle}\n      ref={optionsListRef}\n      // this is to prevent known bug of Chrome when element\n      // loses focus on click on the scrollbar\n      onMouseDown={(e) => e.preventDefault()}\n      data-e2e-test-id=\"optionsList\"\n    >\n      {isVirtualized ? (\n        <VirtualScrollList\n          maxHeight={maxHeight}\n          itemHeight={36}\n          itemAmount={options.length}\n          emptyState={() => (\n            <Box space=\"xs\">\n              <Text>{emptyStateMessage}</Text>\n            </Box>\n          )}\n          containerStyle={dropdownContainerStyle}\n          itemInView={selectedIndex}\n          itemTemplate={renderItem}\n          onContentHeightChange={calculateStyle}\n        />\n      ) : (\n        <StyledListContainer\n          maxHeight={maxHeight}\n          role=\"listbox\"\n          id={getOptionsListId(name)}\n          ref={listContainerRef}\n        >\n          {options.map((_option, index) => renderItem(index))}\n        </StyledListContainer>\n      )}\n    </StyledDropdown>\n  );\n\n  if (!isOpen) {\n    return null;\n  }\n\n  return <Portal portalContainer={portalContainer}>{listElm}</Portal>;\n}\n"],"names":[],"mappings":"AA6CqB"} */"),StyledListContainer=/*#__PURE__*/styled("div",{target:"eknc9an1",label:"StyledListContainer"})(({maxHeight})=>({maxHeight,boxSizing:"border-box",overflow:"auto"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"src/components/Form/Combobox/OptionsList.tsx","sources":["src/components/Form/Combobox/OptionsList.tsx"],"sourcesContent":["import type { RefObject } from \"react\";\nimport React, { useRef, useEffect, useMemo } from \"react\";\nimport styled from \"@emotion/styled\";\nimport { useKeyboard } from \"../../../shared/useKeyboard\";\nimport type { CommonSelectProps, SelectOption } from \"./Combobox\";\nimport { usePopupMenu } from \"../../../shared/popupMenu/usePopupMenu\";\nimport { VirtualScrollList } from \"../../VirtualScrollList/VirtualScrollList\";\nimport { Text } from \"../../Typography/Text/Text\";\nimport { Box } from \"../../Box/Box\";\nimport { Inline } from \"../../Inline/Inline\";\nimport { Icon } from \"../../Icon/Icon\";\nimport { StyledDropdown, StyledOption } from \"./StyledSelectComponents\";\nimport { dropdownContainerStyle } from \"./constants\";\nimport { Stack } from \"../../Stack/Stack\";\nimport { CheckboxRaw } from \"../Checkbox/Checkbox\";\nimport { Portal } from \"../../Portal/Portal\";\n\nexport type OptionsListProps = {\n  isOpen: boolean;\n  isMultiSelect?: boolean;\n  triggerRef: RefObject<HTMLInputElement>;\n  triggerWrapperRef?: RefObject<HTMLDivElement>;\n  onCloseDropdown: (noSelect?: boolean) => void;\n  selectedIndex: number;\n  onSelectedIndexChange: (index: number) => void;\n  forceChangeFakeSelect: (selectedOption: SelectOption) => void;\n  isVirtualized?: boolean;\n  size?: \"m\" | \"s\";\n} & Partial<CommonSelectProps>;\n\nexport function getOptionId(selectName: string, optionValue: string): string {\n  return `${selectName}Option${optionValue}`;\n}\n\nexport function getOptionsListId(selectName: string): string {\n  return `${selectName}OptionsList`;\n}\n\nfunction scrollToItem(list: HTMLDivElement[], itemIndex: number) {\n  list[itemIndex]?.scrollIntoView?.({\n    behavior: \"smooth\",\n    block: \"nearest\",\n  });\n}\n\nconst CustomOption = styled(StyledOption)(({ theme }) => ({\n  // this is needed for using padding of checkboxes in order to use its hover state\n  paddingTop: 0,\n  paddingBottom: 0,\n  \"& > div\": {\n    paddingTop: theme.variables.size.spacing.xs,\n    paddingBottom: theme.variables.size.spacing.xs,\n  },\n  \"& > div *\": {\n    marginTop: 0,\n  },\n}));\n\nconst StyledListContainer = styled.div<Pick<OptionsListProps, \"maxHeight\">>(\n  ({ maxHeight }) => ({\n    maxHeight,\n    boxSizing: \"border-box\",\n    overflow: \"auto\",\n  })\n);\n\nexport function OptionsList({\n  isOpen,\n  isMultiSelect = false,\n  value,\n  disabled,\n  options,\n  portalContainer,\n  triggerRef,\n  triggerWrapperRef,\n  maxHeight,\n  emptyStateMessage,\n  selectedIndex,\n  optionsListWidth,\n  isVirtualized = true,\n  name,\n  size = \"m\",\n  onCloseDropdown,\n  onSelectedIndexChange,\n  forceChangeFakeSelect,\n}: OptionsListProps): React.ReactElement {\n  const optionsListRef = useRef(null);\n  const listContainerRef = useRef(null);\n  const listItemsRef = useRef(null);\n  const refForPositioning = triggerWrapperRef || triggerRef;\n  const activeItemIndex = useMemo(\n    () =>\n      options.findIndex((option) =>\n        isMultiSelect ? value.includes(option.value) : option.value === value\n      ),\n    [options, isMultiSelect, value]\n  );\n\n  const { menuStyle: optionsListStyle, calculateStyle } = usePopupMenu({\n    triggerRef: refForPositioning,\n    menuRef: optionsListRef,\n    isOpen,\n  });\n\n  useEffect(() => {\n    if (\n      isOpen &&\n      listContainerRef.current &&\n      !isVirtualized &&\n      optionsListStyle.top\n    ) {\n      const listElm = listContainerRef.current;\n      // determine overflow\n      if (listElm.clientHeight < listElm.scrollHeight) {\n        listItemsRef.current = listElm.querySelectorAll(\"[data-list-item]\");\n        scrollToItem(listItemsRef.current, activeItemIndex);\n      }\n    } else {\n      listItemsRef.current = null;\n    }\n  }, [\n    isOpen,\n    isVirtualized,\n    listContainerRef,\n    options,\n    maxHeight,\n    optionsListStyle,\n    activeItemIndex,\n  ]);\n\n  useEffect(() => {\n    if (listItemsRef.current) {\n      scrollToItem(listItemsRef.current, selectedIndex);\n    }\n  }, [listItemsRef, selectedIndex]);\n\n  useKeyboard(\n    {\n      Escape: () => onCloseDropdown(true),\n      Enter: () => {\n        const preselectedOption = options[selectedIndex];\n\n        if (!preselectedOption?.disabled) {\n          if (preselectedOption) {\n            forceChangeFakeSelect(preselectedOption);\n            if (!isMultiSelect) {\n              onCloseDropdown(true);\n            }\n            return;\n          }\n          if (!isMultiSelect) {\n            onCloseDropdown();\n          }\n        }\n      },\n      ArrowUp: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex > 0) {\n          newIndex -= 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n      ArrowDown: () => {\n        let newIndex = selectedIndex === -1 ? activeItemIndex : selectedIndex;\n        while (newIndex < options.length - 1) {\n          newIndex += 1;\n          if (!options[newIndex]?.disabled) {\n            break;\n          }\n        }\n        // Only update the selection if the new item is not disabled\n        if (!options[newIndex]?.disabled) {\n          onSelectedIndexChange(newIndex);\n        }\n      },\n    },\n    triggerRef,\n    isOpen && !disabled\n  );\n\n  const renderItem = (index: number) => {\n    const option: SelectOption = options[index];\n    // Generate unique id for the option\n    const id = getOptionId(name, option.value);\n\n    if (isMultiSelect) {\n      const isActive = value.includes(option.value);\n\n      return (\n        <CustomOption\n          role=\"option\"\n          aria-selected={isActive}\n          aria-disabled={option.disabled}\n          id={id}\n          key={option.value}\n          active={isActive}\n          disabled={option.disabled}\n          preSelected={selectedIndex === index}\n          data-list-item\n          onMouseDown={() => {\n            if (!option.disabled) {\n              forceChangeFakeSelect(option);\n            }\n          }}\n          // stop event propagation to not close modal on selection if select is within a Modal\n          onClick={(evt) => evt.stopPropagation()}\n        >\n          <CheckboxRaw\n            name=\"\"\n            disabled={option.disabled}\n            checked={isActive}\n            size=\"s\"\n            label={option.label}\n            onChange={() => null}\n            labelHint={option?.description}\n          />\n        </CustomOption>\n      );\n    }\n\n    // else render single select item\n    const isActive = value === option.value;\n    const optionText = (\n      <Stack space=\"zero\">\n        <Text color=\"primary\" size={size}>\n          {option.label}\n        </Text>\n        {option.description && (\n          <Text color=\"tertiary\" size=\"s\">\n            {option.description}\n          </Text>\n        )}\n      </Stack>\n    );\n    const checkIcon = size === \"s\" ? \"check-small\" : \"check\";\n\n    return (\n      <StyledOption\n        role=\"option\"\n        aria-selected={isActive}\n        aria-disabled={option.disabled}\n        id={id}\n        key={option.value}\n        active={isActive}\n        disabled={option.disabled}\n        preSelected={selectedIndex === index}\n        data-list-item\n        size={size}\n        onMouseDown={() => {\n          if (!option.disabled) {\n            forceChangeFakeSelect(option);\n            onCloseDropdown(true);\n          }\n        }}\n      >\n        {isActive ? (\n          <Inline noWrap alignItems=\"spaceBetween\">\n            {optionText}\n            <Box space=\"zero\" tSpace=\"xxxs\">\n              <Icon name={checkIcon} size=\"s\" color=\"accent\" />\n            </Box>\n          </Inline>\n        ) : (\n          optionText\n        )}\n      </StyledOption>\n    );\n  };\n\n  const listStyle = {\n    ...optionsListStyle,\n    width:\n      optionsListWidth ||\n      refForPositioning.current?.getBoundingClientRect().width,\n  };\n\n  const listElm = (\n    <StyledDropdown\n      style={listStyle}\n      ref={optionsListRef}\n      // this is to prevent known bug of Chrome when element\n      // loses focus on click on the scrollbar\n      onMouseDown={(e) => e.preventDefault()}\n      data-e2e-test-id=\"optionsList\"\n    >\n      {isVirtualized ? (\n        <VirtualScrollList\n          maxHeight={maxHeight}\n          itemHeight={36}\n          itemAmount={options.length}\n          emptyState={() => (\n            <Box space=\"xs\">\n              <Text>{emptyStateMessage}</Text>\n            </Box>\n          )}\n          containerStyle={dropdownContainerStyle}\n          itemInView={selectedIndex}\n          itemTemplate={renderItem}\n          onContentHeightChange={calculateStyle}\n        />\n      ) : (\n        <StyledListContainer\n          maxHeight={maxHeight}\n          role=\"listbox\"\n          id={getOptionsListId(name)}\n          ref={listContainerRef}\n        >\n          {options.map((_option, index) => renderItem(index))}\n        </StyledListContainer>\n      )}\n    </StyledDropdown>\n  );\n\n  if (!isOpen) {\n    return null;\n  }\n\n  return <Portal portalContainer={portalContainer}>{listElm}</Portal>;\n}\n"],"names":[],"mappings":"AA0D4B"} */");export function OptionsList({isOpen,isMultiSelect=!1,value,disabled,options,portalContainer,triggerRef,triggerWrapperRef,maxHeight,emptyStateMessage,selectedIndex,optionsListWidth,isVirtualized=!0,name,size="m",onCloseDropdown,onSelectedIndexChange,forceChangeFakeSelect}){let optionsListRef=useRef(null),listContainerRef=useRef(null),listItemsRef=useRef(null),refForPositioning=triggerWrapperRef||triggerRef,activeItemIndex=useMemo(()=>options.findIndex(option=>isMultiSelect?value.includes(option.value):option.value===value),[options,isMultiSelect,value]),{menuStyle:optionsListStyle,calculateStyle}=usePopupMenu({triggerRef:refForPositioning,menuRef:optionsListRef,isOpen});useEffect(()=>{if(isOpen&&listContainerRef.current&&!isVirtualized&&optionsListStyle.top){let listElm=listContainerRef.current;listElm.clientHeight<listElm.scrollHeight&&(listItemsRef.current=listElm.querySelectorAll("[data-list-item]"),scrollToItem(listItemsRef.current,activeItemIndex))}else listItemsRef.current=null},[isOpen,isVirtualized,listContainerRef,options,maxHeight,optionsListStyle,activeItemIndex]),useEffect(()=>{listItemsRef.current&&scrollToItem(listItemsRef.current,selectedIndex)},[listItemsRef,selectedIndex]),useKeyboard({Escape:()=>onCloseDropdown(!0),Enter:()=>{let preselectedOption=options[selectedIndex];if(!preselectedOption?.disabled){if(preselectedOption){forceChangeFakeSelect(preselectedOption),isMultiSelect||onCloseDropdown(!0);return}isMultiSelect||onCloseDropdown()}},ArrowUp:()=>{let newIndex=-1===selectedIndex?activeItemIndex:selectedIndex;for(;newIndex>0&&(newIndex-=1,options[newIndex]?.disabled););options[newIndex]?.disabled||onSelectedIndexChange(newIndex)},ArrowDown:()=>{let newIndex=-1===selectedIndex?activeItemIndex:selectedIndex;for(;newIndex<options.length-1&&(newIndex+=1,options[newIndex]?.disabled););options[newIndex]?.disabled||onSelectedIndexChange(newIndex)}},triggerRef,isOpen&&!disabled);let renderItem=index=>{let option=options[index],id=getOptionId(name,option.value);if(isMultiSelect){let isActive=value.includes(option.value);return /*#__PURE__*/React.createElement(CustomOption,{role:"option","aria-selected":isActive,"aria-disabled":option.disabled,id:id,key:option.value,active:isActive,disabled:option.disabled,preSelected:selectedIndex===index,"data-list-item":!0,onMouseDown:()=>{option.disabled||forceChangeFakeSelect(option)},onClick:evt=>evt.stopPropagation()},/*#__PURE__*/React.createElement(CheckboxRaw,{name:"",disabled:option.disabled,checked:isActive,size:"s",label:option.label,onChange:()=>null,labelHint:option?.description}))}let isActive=value===option.value,optionText=/*#__PURE__*/React.createElement(Stack,{space:"zero"},/*#__PURE__*/React.createElement(Text,{color:"primary",size:size},option.label),option.description&&/*#__PURE__*/React.createElement(Text,{color:"tertiary",size:"s"},option.description)),checkIcon="s"===size?"check-small":"check";return /*#__PURE__*/React.createElement(StyledOption,{role:"option","aria-selected":isActive,"aria-disabled":option.disabled,id:id,key:option.value,active:isActive,disabled:option.disabled,preSelected:selectedIndex===index,"data-list-item":!0,size:size,onMouseDown:()=>{option.disabled||(forceChangeFakeSelect(option),onCloseDropdown(!0))}},isActive?/*#__PURE__*/React.createElement(Inline,{noWrap:!0,alignItems:"spaceBetween"},optionText,/*#__PURE__*/React.createElement(Box,{space:"zero",tSpace:"xxxs"},/*#__PURE__*/React.createElement(Icon,{name:checkIcon,size:"s",color:"accent"}))):optionText)},listStyle={...optionsListStyle,width:optionsListWidth||refForPositioning.current?.getBoundingClientRect().width},listElm=/*#__PURE__*/React.createElement(StyledDropdown,{style:listStyle,ref:optionsListRef,onMouseDown:e=>e.preventDefault(),"data-e2e-test-id":"optionsList"},isVirtualized?/*#__PURE__*/React.createElement(VirtualScrollList,{maxHeight:maxHeight,itemHeight:36,itemAmount:options.length,emptyState:()=>/*#__PURE__*/React.createElement(Box,{space:"xs"},/*#__PURE__*/React.createElement(Text,null,emptyStateMessage)),containerStyle:dropdownContainerStyle,itemInView:selectedIndex,itemTemplate:renderItem,onContentHeightChange:calculateStyle}):/*#__PURE__*/React.createElement(StyledListContainer,{maxHeight:maxHeight,role:"listbox",id:getOptionsListId(name),ref:listContainerRef},options.map((_option,index)=>renderItem(index))));return isOpen?/*#__PURE__*/React.createElement(Portal,{portalContainer:portalContainer},listElm):null}
@@ -1,3 +1,4 @@
1
+ import type { OptionsListProps } from "./OptionsList";
1
2
  export declare const StyledContainer: import("@emotion/styled").StyledComponent<{
2
3
  theme?: import("@emotion/react").Theme;
3
4
  as?: React.ElementType;
@@ -9,7 +10,7 @@ export declare const StyledOption: import("@emotion/styled").StyledComponent<{
9
10
  active: boolean;
10
11
  preSelected: boolean;
11
12
  disabled: boolean;
12
- }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
13
+ } & Pick<OptionsListProps, "size">, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
13
14
  export declare const StyledFakeInputWrap: import("@emotion/styled").StyledComponent<{
14
15
  theme?: import("@emotion/react").Theme;
15
16
  as?: React.ElementType;
@@ -1 +1 @@
1
- import styled from"@emotion/styled";export const StyledContainer=/*#__PURE__*/styled("div",{target:"e1u5c1re0",label:"StyledContainer"})(()=>({position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRPcHRpb24gPSBzdHlsZWQuZGl2PHtcbiAgYWN0aXZlOiBib29sZWFuO1xuICBwcmVTZWxlY3RlZDogYm9vbGVhbjtcbiAgZGlzYWJsZWQ6IGJvb2xlYW47XG59PigoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQgfSkgPT4ge1xuICBjb25zdCBob3ZlclN0eWxlcyA9IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5ob3ZlcixcbiAgICBib3JkZXJSYWRpdXM6IDAsXG4gIH07XG5cbiAgcmV0dXJuIHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc31gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgLi4uKGFjdGl2ZSAmJiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5hY3RpdmUsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfSksXG4gICAgLi4uKGRpc2FibGVkICYmIHtcbiAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSksXG4gICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICBcIiY6aG92ZXJcIjogaG92ZXJTdHlsZXMsXG4gICAgfSksXG4gICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgfTtcbn0pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUcrQiJ9 */");export const StyledOption=/*#__PURE__*/styled("div",{target:"e1u5c1re1",label:"StyledOption"})(({theme,active,preSelected,disabled})=>{let hoverStyles={backgroundColor:theme.values.color.background.secondary.hover,borderRadius:0};return{padding:`${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,cursor:"pointer",borderRadius:theme.variables.size.borderRadius.xs,...active&&{backgroundColor:theme.values.color.background.secondary.active,borderRadius:0},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.disabled},...!disabled&&{"&:hover":hoverStyles},...preSelected&&hoverStyles}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRPcHRpb24gPSBzdHlsZWQuZGl2PHtcbiAgYWN0aXZlOiBib29sZWFuO1xuICBwcmVTZWxlY3RlZDogYm9vbGVhbjtcbiAgZGlzYWJsZWQ6IGJvb2xlYW47XG59PigoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQgfSkgPT4ge1xuICBjb25zdCBob3ZlclN0eWxlcyA9IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5ob3ZlcixcbiAgICBib3JkZXJSYWRpdXM6IDAsXG4gIH07XG5cbiAgcmV0dXJuIHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc31gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgLi4uKGFjdGl2ZSAmJiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5hY3RpdmUsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfSksXG4gICAgLi4uKGRpc2FibGVkICYmIHtcbiAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSksXG4gICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICBcIiY6aG92ZXJcIjogaG92ZXJTdHlsZXMsXG4gICAgfSksXG4gICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgfTtcbn0pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVU0QiJ9 */");export const StyledFakeInputWrap=/*#__PURE__*/styled("div",{target:"e1u5c1re2",label:"StyledFakeInputWrap"})(()=>({zIndex:0,position:"absolute",pointerEvents:"none",width:"100%",bottom:0,left:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRPcHRpb24gPSBzdHlsZWQuZGl2PHtcbiAgYWN0aXZlOiBib29sZWFuO1xuICBwcmVTZWxlY3RlZDogYm9vbGVhbjtcbiAgZGlzYWJsZWQ6IGJvb2xlYW47XG59PigoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQgfSkgPT4ge1xuICBjb25zdCBob3ZlclN0eWxlcyA9IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5ob3ZlcixcbiAgICBib3JkZXJSYWRpdXM6IDAsXG4gIH07XG5cbiAgcmV0dXJuIHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc31gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgLi4uKGFjdGl2ZSAmJiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5hY3RpdmUsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfSksXG4gICAgLi4uKGRpc2FibGVkICYmIHtcbiAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSksXG4gICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICBcIiY6aG92ZXJcIjogaG92ZXJTdHlsZXMsXG4gICAgfSksXG4gICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgfTtcbn0pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVDbUMifQ== */");export const StyledDropdown=/*#__PURE__*/styled("div",{target:"e1u5c1re3",label:"StyledDropdown"})(({theme})=>({backgroundColor:theme.values.color.background.primary.default,position:"absolute",zIndex:2,borderRadius:theme.variables.size.borderRadius.xs,overflow:"hidden",boxShadow:theme.values.elevation[2],boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkQ29udGFpbmVyID0gc3R5bGVkLmRpdihcbiAgKCkgPT5cbiAgICAoe1xuICAgICAgcG9zaXRpb246IFwicmVsYXRpdmVcIixcbiAgICB9IGFzIENTU09iamVjdClcbik7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRPcHRpb24gPSBzdHlsZWQuZGl2PHtcbiAgYWN0aXZlOiBib29sZWFuO1xuICBwcmVTZWxlY3RlZDogYm9vbGVhbjtcbiAgZGlzYWJsZWQ6IGJvb2xlYW47XG59PigoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQgfSkgPT4ge1xuICBjb25zdCBob3ZlclN0eWxlcyA9IHtcbiAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5ob3ZlcixcbiAgICBib3JkZXJSYWRpdXM6IDAsXG4gIH07XG5cbiAgcmV0dXJuIHtcbiAgICBwYWRkaW5nOiBgJHt0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzfSAke3RoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcuc31gLFxuICAgIGN1cnNvcjogXCJwb2ludGVyXCIsXG4gICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgLi4uKGFjdGl2ZSAmJiB7XG4gICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5iYWNrZ3JvdW5kLnNlY29uZGFyeS5hY3RpdmUsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfSksXG4gICAgLi4uKGRpc2FibGVkICYmIHtcbiAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgb3BhY2l0eTogdGhlbWUudmFyaWFibGVzLm9wYWNpdHkuZGlzYWJsZWQsXG4gICAgfSksXG4gICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICBcIiY6aG92ZXJcIjogaG92ZXJTdHlsZXMsXG4gICAgfSksXG4gICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgfTtcbn0pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1EOEIifQ== */");
1
+ import styled from"@emotion/styled";export const StyledContainer=/*#__PURE__*/styled("div",{target:"ef7m5rw0",label:"StyledContainer"})(()=>({position:"relative"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBPcHRpb25zTGlzdFByb3BzIH0gZnJvbSBcIi4vT3B0aW9uc0xpc3RcIjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG50eXBlIFN0eWxlZE9wdGlvblByb3BzID0ge1xuICBhY3RpdmU6IGJvb2xlYW47XG4gIHByZVNlbGVjdGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPE9wdGlvbnNMaXN0UHJvcHMsIFwic2l6ZVwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZE9wdGlvbiA9IHN0eWxlZC5kaXY8U3R5bGVkT3B0aW9uUHJvcHM+KFxuICAoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQsIHNpemUgfSkgPT4ge1xuICAgIGNvbnN0IGhvdmVyU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuaG92ZXIsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfTtcblxuICAgIHJldHVybiB7XG4gICAgICBwYWRkaW5nOiBgJHtcbiAgICAgICAgc2l6ZSA9PT0gXCJzXCJcbiAgICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzXG4gICAgICB9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgICAuLi4oYWN0aXZlICYmIHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuYWN0aXZlLFxuICAgICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgICB9KSxcbiAgICAgIC4uLihkaXNhYmxlZCAmJiB7XG4gICAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICAgIH0pLFxuICAgICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICAgIFwiJjpob3ZlclwiOiBob3ZlclN0eWxlcyxcbiAgICAgIH0pLFxuICAgICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUkrQiJ9 */");export const StyledOption=/*#__PURE__*/styled("div",{target:"ef7m5rw1",label:"StyledOption"})(({theme,active,preSelected,disabled,size})=>{let hoverStyles={backgroundColor:theme.values.color.background.secondary.hover,borderRadius:0};return{padding:`${"s"===size?theme.variables.size.spacing.xxs:theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,cursor:"pointer",borderRadius:theme.variables.size.borderRadius.xs,...active&&{backgroundColor:theme.values.color.background.secondary.active,borderRadius:0},...disabled&&{cursor:"not-allowed",opacity:theme.variables.opacity.disabled},...!disabled&&{"&:hover":hoverStyles},...preSelected&&hoverStyles}},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBPcHRpb25zTGlzdFByb3BzIH0gZnJvbSBcIi4vT3B0aW9uc0xpc3RcIjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG50eXBlIFN0eWxlZE9wdGlvblByb3BzID0ge1xuICBhY3RpdmU6IGJvb2xlYW47XG4gIHByZVNlbGVjdGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPE9wdGlvbnNMaXN0UHJvcHMsIFwic2l6ZVwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZE9wdGlvbiA9IHN0eWxlZC5kaXY8U3R5bGVkT3B0aW9uUHJvcHM+KFxuICAoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQsIHNpemUgfSkgPT4ge1xuICAgIGNvbnN0IGhvdmVyU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuaG92ZXIsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfTtcblxuICAgIHJldHVybiB7XG4gICAgICBwYWRkaW5nOiBgJHtcbiAgICAgICAgc2l6ZSA9PT0gXCJzXCJcbiAgICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzXG4gICAgICB9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgICAuLi4oYWN0aXZlICYmIHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuYWN0aXZlLFxuICAgICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgICB9KSxcbiAgICAgIC4uLihkaXNhYmxlZCAmJiB7XG4gICAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICAgIH0pLFxuICAgICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICAgIFwiJjpob3ZlclwiOiBob3ZlclN0eWxlcyxcbiAgICAgIH0pLFxuICAgICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCNEIifQ== */");export const StyledFakeInputWrap=/*#__PURE__*/styled("div",{target:"ef7m5rw2",label:"StyledFakeInputWrap"})(()=>({zIndex:0,position:"absolute",pointerEvents:"none",width:"100%",bottom:0,left:0}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBPcHRpb25zTGlzdFByb3BzIH0gZnJvbSBcIi4vT3B0aW9uc0xpc3RcIjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG50eXBlIFN0eWxlZE9wdGlvblByb3BzID0ge1xuICBhY3RpdmU6IGJvb2xlYW47XG4gIHByZVNlbGVjdGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPE9wdGlvbnNMaXN0UHJvcHMsIFwic2l6ZVwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZE9wdGlvbiA9IHN0eWxlZC5kaXY8U3R5bGVkT3B0aW9uUHJvcHM+KFxuICAoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQsIHNpemUgfSkgPT4ge1xuICAgIGNvbnN0IGhvdmVyU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuaG92ZXIsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfTtcblxuICAgIHJldHVybiB7XG4gICAgICBwYWRkaW5nOiBgJHtcbiAgICAgICAgc2l6ZSA9PT0gXCJzXCJcbiAgICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzXG4gICAgICB9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgICAuLi4oYWN0aXZlICYmIHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuYWN0aXZlLFxuICAgICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgICB9KSxcbiAgICAgIC4uLihkaXNhYmxlZCAmJiB7XG4gICAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICAgIH0pLFxuICAgICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICAgIFwiJjpob3ZlclwiOiBob3ZlclN0eWxlcyxcbiAgICAgIH0pLFxuICAgICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdEbUMifQ== */");export const StyledDropdown=/*#__PURE__*/styled("div",{target:"ef7m5rw3",label:"StyledDropdown"})(({theme})=>({backgroundColor:theme.values.color.background.primary.default,position:"absolute",zIndex:2,borderRadius:theme.variables.size.borderRadius.xs,overflow:"hidden",boxShadow:theme.values.elevation[2],boxSizing:"border-box"}),"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCIsInNvdXJjZXMiOlsic3JjL2NvbXBvbmVudHMvRm9ybS9Db21ib2JveC9TdHlsZWRTZWxlY3RDb21wb25lbnRzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU09iamVjdCB9IGZyb20gXCJAZW1vdGlvbi9zdHlsZWRcIjtcbmltcG9ydCBzdHlsZWQgZnJvbSBcIkBlbW90aW9uL3N0eWxlZFwiO1xuaW1wb3J0IHR5cGUgeyBPcHRpb25zTGlzdFByb3BzIH0gZnJvbSBcIi4vT3B0aW9uc0xpc3RcIjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHBvc2l0aW9uOiBcInJlbGF0aXZlXCIsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG50eXBlIFN0eWxlZE9wdGlvblByb3BzID0ge1xuICBhY3RpdmU6IGJvb2xlYW47XG4gIHByZVNlbGVjdGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPE9wdGlvbnNMaXN0UHJvcHMsIFwic2l6ZVwiPjtcblxuZXhwb3J0IGNvbnN0IFN0eWxlZE9wdGlvbiA9IHN0eWxlZC5kaXY8U3R5bGVkT3B0aW9uUHJvcHM+KFxuICAoeyB0aGVtZSwgYWN0aXZlLCBwcmVTZWxlY3RlZCwgZGlzYWJsZWQsIHNpemUgfSkgPT4ge1xuICAgIGNvbnN0IGhvdmVyU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuaG92ZXIsXG4gICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgfTtcblxuICAgIHJldHVybiB7XG4gICAgICBwYWRkaW5nOiBgJHtcbiAgICAgICAgc2l6ZSA9PT0gXCJzXCJcbiAgICAgICAgICA/IHRoZW1lLnZhcmlhYmxlcy5zaXplLnNwYWNpbmcueHhzXG4gICAgICAgICAgOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5zcGFjaW5nLnhzXG4gICAgICB9ICR7dGhlbWUudmFyaWFibGVzLnNpemUuc3BhY2luZy5zfWAsXG4gICAgICBjdXJzb3I6IFwicG9pbnRlclwiLFxuICAgICAgYm9yZGVyUmFkaXVzOiB0aGVtZS52YXJpYWJsZXMuc2l6ZS5ib3JkZXJSYWRpdXMueHMsXG4gICAgICAuLi4oYWN0aXZlICYmIHtcbiAgICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5zZWNvbmRhcnkuYWN0aXZlLFxuICAgICAgICBib3JkZXJSYWRpdXM6IDAsXG4gICAgICB9KSxcbiAgICAgIC4uLihkaXNhYmxlZCAmJiB7XG4gICAgICAgIGN1cnNvcjogXCJub3QtYWxsb3dlZFwiLFxuICAgICAgICBvcGFjaXR5OiB0aGVtZS52YXJpYWJsZXMub3BhY2l0eS5kaXNhYmxlZCxcbiAgICAgIH0pLFxuICAgICAgLi4uKCFkaXNhYmxlZCAmJiB7XG4gICAgICAgIFwiJjpob3ZlclwiOiBob3ZlclN0eWxlcyxcbiAgICAgIH0pLFxuICAgICAgLi4uKHByZVNlbGVjdGVkICYmIGhvdmVyU3R5bGVzKSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRmFrZUlucHV0V3JhcCA9IHN0eWxlZC5kaXYoXG4gICgpID0+XG4gICAgKHtcbiAgICAgIHpJbmRleDogMCxcbiAgICAgIHBvc2l0aW9uOiBcImFic29sdXRlXCIsXG4gICAgICBwb2ludGVyRXZlbnRzOiBcIm5vbmVcIixcbiAgICAgIHdpZHRoOiBcIjEwMCVcIixcbiAgICAgIGJvdHRvbTogMCxcbiAgICAgIGxlZnQ6IDAsXG4gICAgfSBhcyBDU1NPYmplY3QpXG4pO1xuXG5leHBvcnQgY29uc3QgU3R5bGVkRHJvcGRvd24gPSBzdHlsZWQuZGl2KCh7IHRoZW1lIH0pID0+ICh7XG4gIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICBwb3NpdGlvbjogXCJhYnNvbHV0ZVwiLFxuICB6SW5kZXg6IDIsXG4gIGJvcmRlclJhZGl1czogdGhlbWUudmFyaWFibGVzLnNpemUuYm9yZGVyUmFkaXVzLnhzLFxuICBvdmVyZmxvdzogXCJoaWRkZW5cIixcbiAgYm94U2hhZG93OiB0aGVtZS52YWx1ZXMuZWxldmF0aW9uWzJdLFxuICBib3hTaXppbmc6IFwiYm9yZGVyLWJveFwiLFxufSkpO1xuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTREOEIifQ== */");
@@ -1 +1 @@
1
- import React,{Fragment}from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{SegmentedControlOption}from"./SegmentedControlOption";import breakpoints from"../../../web-tokens/_breakpoints.json";let StyledDivider=/*#__PURE__*/styled("div",{target:"egd5ttj0",label:"StyledDivider"})(({theme,isChecked,isDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,baseStyles={backgroundColor:theme.values.color.background.primary.default},checkedStyle=isChecked&&{borderColor:theme.values.color.border.accentSubtle.default,...isDisabled&&{opacity:theme.variables.opacity.disabled}},borderRightStyle={borderRight:border,...baseStyles,...checkedStyle};return justified?{[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderRightStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{borderBottom:border,...baseStyles,...checkedStyle}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGlzRGlzYWJsZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgfSksXG4gICAgfTtcblxuICAgIGNvbnN0IGJvcmRlclJpZ2h0U3R5bGUgPSB7XG4gICAgICBib3JkZXJSaWdodDogYm9yZGVyLFxuICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLmJhc2VTdHlsZXMsXG4gICAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxudHlwZSBTdHlsZWRDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFNlZ21lbnRlZENvbnRyb2xQcm9wcyxcbiAgXCJqdXN0aWZpZWRcIiB8IFwib3B0aW9uc1wiXG4+O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0eWxlZENvbnRhaW5lclByb3BzPihcbiAgKHsganVzdGlmaWVkLCBvcHRpb25zIH0pID0+IHtcbiAgICBjb25zdCBiYXNlU3R5bGUgPSB7XG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBiYXNlU3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmJhc2VTdHlsZSxcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG5cbiAgICAgIFwiJiA+ICpcIjoge1xuICAgICAgICBmbGV4OiBgMSAxICR7MTAwIC8gb3B0aW9ucy5sZW5ndGh9JWAsXG4gICAgICB9LFxuXG4gICAgICBbYCYgPiAke1N0eWxlZERpdmlkZXJ9YF06IHtcbiAgICAgICAgZmxleDogXCIwIDAgYXV0b1wiLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIHRhYmxldCBhbmQgZGVza3RvcFxuICAgICAgW2BAbWVkaWEgKG1pbi13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZENvbnRyb2woe1xuICBvcHRpb25zLFxuICB2YWx1ZSxcbiAganVzdGlmaWVkLFxuICBzaXplID0gXCJtXCIsXG4gIG9uQ2hhbmdlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICAgIGlzQ2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNEaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBqdXN0aWZpZWQ9e2p1c3RpZmllZH1cbiAgICAgICAgICAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFjc0IifQ== */"),StyledContainer=/*#__PURE__*/styled("div",{target:"egd5ttj1",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbn0gJiBQaWNrPFNlZ21lbnRlZENvbnRyb2xQcm9wcywgXCJqdXN0aWZpZWRcIj47XG5cbmNvbnN0IFN0eWxlZERpdmlkZXIgPSBzdHlsZWQuZGl2PFN0eWxlZERpdmlkZXJQcm9wcz4oXG4gICh7IHRoZW1lLCBpc0NoZWNrZWQsIGlzRGlzYWJsZWQsIGp1c3RpZmllZCB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBiYXNlU3R5bGVzID0ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGVtZS52YWx1ZXMuY29sb3IuYmFja2dyb3VuZC5wcmltYXJ5LmRlZmF1bHQsXG4gICAgfTtcbiAgICBjb25zdCBjaGVja2VkU3R5bGUgPSBpc0NoZWNrZWQgJiYge1xuICAgICAgYm9yZGVyQ29sb3I6IHRoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuYWNjZW50U3VidGxlLmRlZmF1bHQsXG4gICAgICAuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgfSksXG4gICAgfTtcblxuICAgIGNvbnN0IGJvcmRlclJpZ2h0U3R5bGUgPSB7XG4gICAgICBib3JkZXJSaWdodDogYm9yZGVyLFxuICAgICAgLi4uYmFzZVN0eWxlcyxcbiAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLmJhc2VTdHlsZXMsXG4gICAgICAgIC4uLmNoZWNrZWRTdHlsZSxcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxudHlwZSBTdHlsZWRDb250YWluZXJQcm9wcyA9IFBpY2s8XG4gIFNlZ21lbnRlZENvbnRyb2xQcm9wcyxcbiAgXCJqdXN0aWZpZWRcIiB8IFwib3B0aW9uc1wiXG4+O1xuXG5jb25zdCBTdHlsZWRDb250YWluZXIgPSBzdHlsZWQuZGl2PFN0eWxlZENvbnRhaW5lclByb3BzPihcbiAgKHsganVzdGlmaWVkLCBvcHRpb25zIH0pID0+IHtcbiAgICBjb25zdCBiYXNlU3R5bGUgPSB7XG4gICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBiYXNlU3R5bGU7XG4gICAgfVxuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLmJhc2VTdHlsZSxcbiAgICAgIGZsZXhEaXJlY3Rpb246IFwiY29sdW1uXCIsXG5cbiAgICAgIFwiJiA+ICpcIjoge1xuICAgICAgICBmbGV4OiBgMSAxICR7MTAwIC8gb3B0aW9ucy5sZW5ndGh9JWAsXG4gICAgICB9LFxuXG4gICAgICBbYCYgPiAke1N0eWxlZERpdmlkZXJ9YF06IHtcbiAgICAgICAgZmxleDogXCIwIDAgYXV0b1wiLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIHRhYmxldCBhbmQgZGVza3RvcFxuICAgICAgW2BAbWVkaWEgKG1pbi13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgZmxleERpcmVjdGlvbjogXCJyb3dcIixcbiAgICAgIH0sXG4gICAgfTtcbiAgfVxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIFNlZ21lbnRlZENvbnRyb2woe1xuICBvcHRpb25zLFxuICB2YWx1ZSxcbiAganVzdGlmaWVkLFxuICBzaXplID0gXCJtXCIsXG4gIG9uQ2hhbmdlLFxuICAuLi5yZXN0XG59OiBTZWdtZW50ZWRDb250cm9sUHJvcHMpOiBSZWFjdEVsZW1lbnQge1xuICBjb25zdCBoYW5kbGVDaGFuZ2U6IEZvcm1FdmVudEhhbmRsZXI8SFRNTElucHV0RWxlbWVudD4gPSAoZXZ0KSA9PiB7XG4gICAgb25DaGFuZ2UoKGV2dC50YXJnZXQgYXMgSFRNTElucHV0RWxlbWVudCkudmFsdWUpO1xuICB9O1xuXG4gIGNvbnN0IG9wdGlvbkVsbXMgPSBvcHRpb25zLm1hcChcbiAgICAoeyB2YWx1ZTogb3B0aW9uVmFsdWUsIGRpc2FibGVkLCAuLi5vdGhlclByb3BzIH0sIGluZGV4KSA9PiB7XG4gICAgICBjb25zdCBpc0NoZWNrZWQgPSB2YWx1ZSA9PT0gb3B0aW9uVmFsdWU7XG4gICAgICBjb25zdCBkaXZpZGVyRWxtID1cbiAgICAgICAgaW5kZXggIT09IDAgPyAoXG4gICAgICAgICAgPFN0eWxlZERpdmlkZXJcbiAgICAgICAgICAgIGlzQ2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNEaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBqdXN0aWZpZWQ9e2p1c3RpZmllZH1cbiAgICAgICAgICAvPlxuICAgICAgICApIDogbnVsbDtcblxuICAgICAgcmV0dXJuIChcbiAgICAgICAgPEZyYWdtZW50IGtleT17b3B0aW9uVmFsdWV9PlxuICAgICAgICAgIHtkaXZpZGVyRWxtfVxuICAgICAgICAgIDxTZWdtZW50ZWRDb250cm9sT3B0aW9uXG4gICAgICAgICAgICB2YWx1ZT17b3B0aW9uVmFsdWV9XG4gICAgICAgICAgICBzaXplPXtzaXplfVxuICAgICAgICAgICAgY2hlY2tlZD17aXNDaGVja2VkfVxuICAgICAgICAgICAgaXNSZXNwb25zaXZlPXtqdXN0aWZpZWR9XG4gICAgICAgICAgICBkaXNhYmxlZD17ZGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNoYW5nZT17aGFuZGxlQ2hhbmdlfVxuICAgICAgICAgICAgey4uLm90aGVyUHJvcHN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9GcmFnbWVudD5cbiAgICAgICk7XG4gICAgfVxuICApO1xuXG4gIHJldHVybiAoXG4gICAgPEZvcm1GaWVsZCBkYXRhLWRzLWlkPVwiU2VnbWVudGVkQ29udHJvbFwiIHsuLi5yZXN0fT5cbiAgICAgIDxTdHlsZWRDb250YWluZXIganVzdGlmaWVkPXtqdXN0aWZpZWR9IG9wdGlvbnM9e29wdGlvbnN9PlxuICAgICAgICB7b3B0aW9uRWxtc31cbiAgICAgIDwvU3R5bGVkQ29udGFpbmVyPlxuICAgIDwvRm9ybUZpZWxkPlxuICApO1xufVxuXG4vKiBlc2xpbnQtZW5hYmxlIHJlYWN0L2pzeC1wcm9wcy1uby1zcHJlYWRpbmcgKi9cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRHdCIn0= */");export function SegmentedControl({options,value,justified,size="m",onChange,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?/*#__PURE__*/React.createElement(StyledDivider,{isChecked:isChecked,isDisabled:disabled,justified:justified}):null;return /*#__PURE__*/React.createElement(Fragment,{key:optionValue},dividerElm,/*#__PURE__*/React.createElement(SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return /*#__PURE__*/React.createElement(FormField,{"data-ds-id":"SegmentedControl",...rest},/*#__PURE__*/React.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
1
+ import React,{Fragment}from"react";import styled from"@emotion/styled";import{FormField}from"../FormField/FormField";import{SegmentedControlOption}from"./SegmentedControlOption";import breakpoints from"../../../web-tokens/_breakpoints.json";let StyledDivider=/*#__PURE__*/styled("div",{target:"e1ewpmhp0",label:"StyledDivider"})(({theme,isChecked,isDisabled,isPrevOptionChecked,isPrevOptionDisabled,justified})=>{let border=`1px solid ${theme.values.color.border.secondary.default}`,otherStyles={backgroundColor:theme.values.color.background.primary.default,...(isChecked||isPrevOptionChecked)&&{borderColor:theme.values.color.border.accentSubtle.default},...isDisabled&&isPrevOptionDisabled&&{opacity:theme.variables.opacity.disabled}},borderRightStyle={borderRight:border,...otherStyles};return justified?{[`@media (min-width: ${breakpoints.medium.value}px)`]:{...borderRightStyle},[`@media (max-width: ${breakpoints.medium.value}px)`]:{borderBottom:border,...otherStyles}}:borderRightStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnRTdWJ0bGUuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLm90aGVyU3R5bGVzLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIC4uLnJlc3Rcbn06IFNlZ21lbnRlZENvbnRyb2xQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBvbkNoYW5nZSgoZXZ0LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS52YWx1ZSk7XG4gIH07XG5cbiAgY29uc3Qgb3B0aW9uRWxtcyA9IG9wdGlvbnMubWFwKFxuICAgICh7IHZhbHVlOiBvcHRpb25WYWx1ZSwgZGlzYWJsZWQsIC4uLm90aGVyUHJvcHMgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGlzQ2hlY2tlZCA9IHZhbHVlID09PSBvcHRpb25WYWx1ZTtcbiAgICAgIGNvbnN0IGRpdmlkZXJFbG0gPVxuICAgICAgICBpbmRleCAhPT0gMCA/IChcbiAgICAgICAgICA8U3R5bGVkRGl2aWRlclxuICAgICAgICAgICAgaXNQcmV2T3B0aW9uQ2hlY2tlZD17b3B0aW9uc1tpbmRleCAtIDFdLnZhbHVlID09PSB2YWx1ZX1cbiAgICAgICAgICAgIGlzUHJldk9wdGlvbkRpc2FibGVkPXtvcHRpb25zW2luZGV4IC0gMV0uZGlzYWJsZWR9XG4gICAgICAgICAgICBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAganVzdGlmaWVkPXtqdXN0aWZpZWR9XG4gICAgICAgICAgLz5cbiAgICAgICAgKSA6IG51bGw7XG5cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxGcmFnbWVudCBrZXk9e29wdGlvblZhbHVlfT5cbiAgICAgICAgICB7ZGl2aWRlckVsbX1cbiAgICAgICAgICA8U2VnbWVudGVkQ29udHJvbE9wdGlvblxuICAgICAgICAgICAgdmFsdWU9e29wdGlvblZhbHVlfVxuICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgIGNoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICAgIGlzUmVzcG9uc2l2ZT17anVzdGlmaWVkfVxuICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX1cbiAgICAgICAgICAgIHsuLi5vdGhlclByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICApO1xuICAgIH1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxGb3JtRmllbGQgZGF0YS1kcy1pZD1cIlNlZ21lbnRlZENvbnRyb2xcIiB7Li4ucmVzdH0+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cblxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JzQiJ9 */"),StyledContainer=/*#__PURE__*/styled("div",{target:"e1ewpmhp1",label:"StyledContainer"})(({justified,options})=>{let baseStyle={display:"flex"};return justified?{...baseStyle,flexDirection:"column","& > *":{flex:`1 1 ${100/options.length}%`},[`& > ${StyledDivider}`]:{flex:"0 0 auto"},[`@media (min-width: ${breakpoints.medium.value}px)`]:{flexDirection:"row"}}:baseStyle},"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3JjL2NvbXBvbmVudHMvRm9ybS9TZWdtZW50ZWRDb250cm9sL1NlZ21lbnRlZENvbnRyb2wudHN4Iiwic291cmNlcyI6WyJzcmMvY29tcG9uZW50cy9Gb3JtL1NlZ21lbnRlZENvbnRyb2wvU2VnbWVudGVkQ29udHJvbC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgcmVhY3QvanN4LXByb3BzLW5vLXNwcmVhZGluZyAqL1xuaW1wb3J0IFJlYWN0LCB7IEZyYWdtZW50IH0gZnJvbSBcInJlYWN0XCI7XG5pbXBvcnQgdHlwZSB7IEZvcm1FdmVudEhhbmRsZXIsIFJlYWN0RWxlbWVudCB9IGZyb20gXCJyZWFjdFwiO1xuaW1wb3J0IHN0eWxlZCBmcm9tIFwiQGVtb3Rpb24vc3R5bGVkXCI7XG5pbXBvcnQgdHlwZSB7IFNlZ21lbnRlZENvbnRyb2xQcm9wcyB9IGZyb20gXCIuLy10eXBlc1wiO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSBcIi4uL0Zvcm1GaWVsZC9Gb3JtRmllbGRcIjtcbmltcG9ydCB7IFNlZ21lbnRlZENvbnRyb2xPcHRpb24gfSBmcm9tIFwiLi9TZWdtZW50ZWRDb250cm9sT3B0aW9uXCI7XG5pbXBvcnQgYnJlYWtwb2ludHMgZnJvbSBcIi4uLy4uLy4uL3dlYi10b2tlbnMvX2JyZWFrcG9pbnRzLmpzb25cIjtcblxudHlwZSBTdHlsZWREaXZpZGVyUHJvcHMgPSB7XG4gIGlzQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uQ2hlY2tlZDogYm9vbGVhbjtcbiAgaXNQcmV2T3B0aW9uRGlzYWJsZWQ6IGJvb2xlYW47XG59ICYgUGljazxTZWdtZW50ZWRDb250cm9sUHJvcHMsIFwianVzdGlmaWVkXCI+O1xuXG5jb25zdCBTdHlsZWREaXZpZGVyID0gc3R5bGVkLmRpdjxTdHlsZWREaXZpZGVyUHJvcHM+KFxuICAoe1xuICAgIHRoZW1lLFxuICAgIGlzQ2hlY2tlZCxcbiAgICBpc0Rpc2FibGVkLFxuICAgIGlzUHJldk9wdGlvbkNoZWNrZWQsXG4gICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQsXG4gICAganVzdGlmaWVkLFxuICB9KSA9PiB7XG4gICAgY29uc3QgYm9yZGVyID0gYDFweCBzb2xpZCAke3RoZW1lLnZhbHVlcy5jb2xvci5ib3JkZXIuc2Vjb25kYXJ5LmRlZmF1bHR9YDtcbiAgICBjb25zdCBvdGhlclN0eWxlcyA9IHtcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJhY2tncm91bmQucHJpbWFyeS5kZWZhdWx0LFxuICAgICAgLi4uKChpc0NoZWNrZWQgfHwgaXNQcmV2T3B0aW9uQ2hlY2tlZCkgJiYge1xuICAgICAgICBib3JkZXJDb2xvcjogdGhlbWUudmFsdWVzLmNvbG9yLmJvcmRlci5hY2NlbnRTdWJ0bGUuZGVmYXVsdCxcbiAgICAgIH0pLFxuICAgICAgLi4uKGlzRGlzYWJsZWQgJiZcbiAgICAgICAgaXNQcmV2T3B0aW9uRGlzYWJsZWQgJiYge1xuICAgICAgICAgIG9wYWNpdHk6IHRoZW1lLnZhcmlhYmxlcy5vcGFjaXR5LmRpc2FibGVkLFxuICAgICAgICB9KSxcbiAgICB9O1xuXG4gICAgY29uc3QgYm9yZGVyUmlnaHRTdHlsZSA9IHtcbiAgICAgIGJvcmRlclJpZ2h0OiBib3JkZXIsXG4gICAgICAuLi5vdGhlclN0eWxlcyxcbiAgICB9O1xuXG4gICAgaWYgKCFqdXN0aWZpZWQpIHtcbiAgICAgIHJldHVybiBib3JkZXJSaWdodFN0eWxlO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICAuLi5ib3JkZXJSaWdodFN0eWxlLFxuICAgICAgfSxcblxuICAgICAgLy8gTGF5b3V0IG9uIG1vYmlsZVxuICAgICAgW2BAbWVkaWEgKG1heC13aWR0aDogJHticmVha3BvaW50cy5tZWRpdW0udmFsdWV9cHgpYF06IHtcbiAgICAgICAgYm9yZGVyQm90dG9tOiBib3JkZXIsXG4gICAgICAgIC4uLm90aGVyU3R5bGVzLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG50eXBlIFN0eWxlZENvbnRhaW5lclByb3BzID0gUGljazxcbiAgU2VnbWVudGVkQ29udHJvbFByb3BzLFxuICBcImp1c3RpZmllZFwiIHwgXCJvcHRpb25zXCJcbj47XG5cbmNvbnN0IFN0eWxlZENvbnRhaW5lciA9IHN0eWxlZC5kaXY8U3R5bGVkQ29udGFpbmVyUHJvcHM+KFxuICAoeyBqdXN0aWZpZWQsIG9wdGlvbnMgfSkgPT4ge1xuICAgIGNvbnN0IGJhc2VTdHlsZSA9IHtcbiAgICAgIGRpc3BsYXk6IFwiZmxleFwiLFxuICAgIH07XG5cbiAgICBpZiAoIWp1c3RpZmllZCkge1xuICAgICAgcmV0dXJuIGJhc2VTdHlsZTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgLi4uYmFzZVN0eWxlLFxuICAgICAgZmxleERpcmVjdGlvbjogXCJjb2x1bW5cIixcblxuICAgICAgXCImID4gKlwiOiB7XG4gICAgICAgIGZsZXg6IGAxIDEgJHsxMDAgLyBvcHRpb25zLmxlbmd0aH0lYCxcbiAgICAgIH0sXG5cbiAgICAgIFtgJiA+ICR7U3R5bGVkRGl2aWRlcn1gXToge1xuICAgICAgICBmbGV4OiBcIjAgMCBhdXRvXCIsXG4gICAgICB9LFxuXG4gICAgICAvLyBMYXlvdXQgb24gdGFibGV0IGFuZCBkZXNrdG9wXG4gICAgICBbYEBtZWRpYSAobWluLXdpZHRoOiAke2JyZWFrcG9pbnRzLm1lZGl1bS52YWx1ZX1weClgXToge1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiBcInJvd1wiLFxuICAgICAgfSxcbiAgICB9O1xuICB9XG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gU2VnbWVudGVkQ29udHJvbCh7XG4gIG9wdGlvbnMsXG4gIHZhbHVlLFxuICBqdXN0aWZpZWQsXG4gIHNpemUgPSBcIm1cIixcbiAgb25DaGFuZ2UsXG4gIC4uLnJlc3Rcbn06IFNlZ21lbnRlZENvbnRyb2xQcm9wcyk6IFJlYWN0RWxlbWVudCB7XG4gIGNvbnN0IGhhbmRsZUNoYW5nZTogRm9ybUV2ZW50SGFuZGxlcjxIVE1MSW5wdXRFbGVtZW50PiA9IChldnQpID0+IHtcbiAgICBvbkNoYW5nZSgoZXZ0LnRhcmdldCBhcyBIVE1MSW5wdXRFbGVtZW50KS52YWx1ZSk7XG4gIH07XG5cbiAgY29uc3Qgb3B0aW9uRWxtcyA9IG9wdGlvbnMubWFwKFxuICAgICh7IHZhbHVlOiBvcHRpb25WYWx1ZSwgZGlzYWJsZWQsIC4uLm90aGVyUHJvcHMgfSwgaW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IGlzQ2hlY2tlZCA9IHZhbHVlID09PSBvcHRpb25WYWx1ZTtcbiAgICAgIGNvbnN0IGRpdmlkZXJFbG0gPVxuICAgICAgICBpbmRleCAhPT0gMCA/IChcbiAgICAgICAgICA8U3R5bGVkRGl2aWRlclxuICAgICAgICAgICAgaXNQcmV2T3B0aW9uQ2hlY2tlZD17b3B0aW9uc1tpbmRleCAtIDFdLnZhbHVlID09PSB2YWx1ZX1cbiAgICAgICAgICAgIGlzUHJldk9wdGlvbkRpc2FibGVkPXtvcHRpb25zW2luZGV4IC0gMV0uZGlzYWJsZWR9XG4gICAgICAgICAgICBpc0NoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAganVzdGlmaWVkPXtqdXN0aWZpZWR9XG4gICAgICAgICAgLz5cbiAgICAgICAgKSA6IG51bGw7XG5cbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxGcmFnbWVudCBrZXk9e29wdGlvblZhbHVlfT5cbiAgICAgICAgICB7ZGl2aWRlckVsbX1cbiAgICAgICAgICA8U2VnbWVudGVkQ29udHJvbE9wdGlvblxuICAgICAgICAgICAgdmFsdWU9e29wdGlvblZhbHVlfVxuICAgICAgICAgICAgc2l6ZT17c2l6ZX1cbiAgICAgICAgICAgIGNoZWNrZWQ9e2lzQ2hlY2tlZH1cbiAgICAgICAgICAgIGlzUmVzcG9uc2l2ZT17anVzdGlmaWVkfVxuICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgb25DaGFuZ2U9e2hhbmRsZUNoYW5nZX1cbiAgICAgICAgICAgIHsuLi5vdGhlclByb3BzfVxuICAgICAgICAgIC8+XG4gICAgICAgIDwvRnJhZ21lbnQ+XG4gICAgICApO1xuICAgIH1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxGb3JtRmllbGQgZGF0YS1kcy1pZD1cIlNlZ21lbnRlZENvbnRyb2xcIiB7Li4ucmVzdH0+XG4gICAgICA8U3R5bGVkQ29udGFpbmVyIGp1c3RpZmllZD17anVzdGlmaWVkfSBvcHRpb25zPXtvcHRpb25zfT5cbiAgICAgICAge29wdGlvbkVsbXN9XG4gICAgICA8L1N0eWxlZENvbnRhaW5lcj5cbiAgICA8L0Zvcm1GaWVsZD5cbiAgKTtcbn1cblxuLyogZXNsaW50LWVuYWJsZSByZWFjdC9qc3gtcHJvcHMtbm8tc3ByZWFkaW5nICovXG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0V3QiJ9 */");export function SegmentedControl({options,value,justified,size="m",onChange,...rest}){let handleChange=evt=>{onChange(evt.target.value)},optionElms=options.map(({value:optionValue,disabled,...otherProps},index)=>{let isChecked=value===optionValue,dividerElm=0!==index?/*#__PURE__*/React.createElement(StyledDivider,{isPrevOptionChecked:options[index-1].value===value,isPrevOptionDisabled:options[index-1].disabled,isChecked:isChecked,isDisabled:disabled,justified:justified}):null;return /*#__PURE__*/React.createElement(Fragment,{key:optionValue},dividerElm,/*#__PURE__*/React.createElement(SegmentedControlOption,{value:optionValue,size:size,checked:isChecked,isResponsive:justified,disabled:disabled,onChange:handleChange,...otherProps}))});return /*#__PURE__*/React.createElement(FormField,{"data-ds-id":"SegmentedControl",...rest},/*#__PURE__*/React.createElement(StyledContainer,{justified:justified,options:options},optionElms))}
@@ -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"../../../shared/ScreenReaderText";import{Tooltip}from"../../Tooltip/Tooltip";import{Inline}from"../../Inline/Inline";let StyledInput=/*#__PURE__*/styled("input",{target:"eq45scu0",label:"StyledInput"})(({theme})=>({opacity:theme.variables.opacity.hidden,height:0,width:0,position:"absolute"}),"/*# 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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=/*#__PURE__*/styled(Text,{target:"eq45scu1",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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkBoB"} */"),StyledSublabel=/*#__PURE__*/styled(Text,{target:"eq45scu2",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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA2BuB"} */"),StyledIconContainer=/*#__PURE__*/styled("div",{target:"eq45scu3",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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiD4B"} */"),StyledContainer=/*#__PURE__*/styled("label",{target:"eq45scu4",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={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",position:"relative",...("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,"& + div":{borderColor:theme.values.color.border.accentSubtle.default,...disabled&&{opacity:theme.variables.opacity.disabled}}},[`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]:{color:theme.values.color.text.secondary.default,...checked&&{color:theme.values.color.text.accent.default}},"input:focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}};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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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        // Set succeeding divider style\n        \"& + div\": {\n          borderColor: theme.values.color.border.accentSubtle.default,\n          ...(disabled && {\n            opacity: theme.variables.opacity.disabled,\n          }),\n        },\n      }),\n\n      [`${StyledSublabel}, ${StyledLabel}, ${StyledIconContainer}`]: {\n        color: theme.values.color.text.secondary.default,\n\n        ...(checked && {\n          color: theme.values.color.text.accent.default,\n        }),\n      },\n\n      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8DwB"} */");export function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus}){let containerRef=useRef(),iconElm=iconName?/*#__PURE__*/React.createElement(StyledIconContainer,null,/*#__PURE__*/React.createElement(Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=/*#__PURE__*/React.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?/*#__PURE__*/React.createElement(React.Fragment,null,iconElm,/*#__PURE__*/React.createElement(ScreenReaderText,null,label)):/*#__PURE__*/React.createElement(Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?/*#__PURE__*/React.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return /*#__PURE__*/React.createElement(React.Fragment,null,/*#__PURE__*/React.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled},/*#__PURE__*/React.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&/*#__PURE__*/React.createElement(Tooltip,{content:tooltipContent,externalTriggerRef:containerRef}))}
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"../../../shared/ScreenReaderText";import{Tooltip}from"../../Tooltip/Tooltip";import{Inline}from"../../Inline/Inline";let StyledInput=/*#__PURE__*/styled("input",{target:"e2n2u3d0",label:"StyledInput"})(({theme})=>({opacity:theme.variables.opacity.hidden,height:0,width:0,position:"absolute"}),"/*# 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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAWoB"} */"),StyledLabel=/*#__PURE__*/styled(Text,{target:"e2n2u3d1",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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAkBoB"} */"),StyledSublabel=/*#__PURE__*/styled(Text,{target:"e2n2u3d2",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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA2BuB"} */"),StyledIconContainer=/*#__PURE__*/styled("div",{target:"e2n2u3d3",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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AAiD4B"} */"),StyledContainer=/*#__PURE__*/styled("label",{target:"e2n2u3d4",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={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",position:"relative",...("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}},"input:focus-visible + &":{outlineWidth:"2px",outlineStyle:"solid",outlineColor:"Highlight"},"@media (-webkit-min-device-pixel-ratio:0)":{"input: focus-visible + &":{outlineColor:"-webkit-focus-ring-color",outlineStyle:"auto"}}};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 \"../../../shared/ScreenReaderText\";\nimport { Tooltip } from \"../../Tooltip/Tooltip\";\nimport { Inline } from \"../../Inline/Inline\";\nimport type { SegmentedControlOptionProps } from \"./-types\";\n\nconst StyledInput = styled.input(({ theme }) => ({\n  opacity: theme.variables.opacity.hidden,\n  height: 0,\n  width: 0,\n  position: \"absolute\",\n}));\n\nconst StyledLabel = styled(Text)(({ theme, size }) => ({\n  ...(size === \"s\" && {\n    lineHeight: theme.variables.size.lineHeight.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      cursor: \"pointer\",\n      backgroundColor: theme.values.color.background.primary.default,\n      display: \"flex\",\n      flexDirection: \"column\" as const,\n      justifyContent: \"center\",\n      alignItems: \"center\",\n      padding: iconOnly\n        ? theme.variables.size.spacing.xs\n        : `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.m}`,\n      border: `1px solid ${theme.values.color.border.secondary.default}`,\n      borderLeftStyle: \"none\" as const,\n      borderRightStyle: \"none\" as const,\n      position: \"relative\" as const,\n\n      ...((size === \"m\" || size === \"l\") && {\n        padding: iconOnly\n          ? theme.variables.size.spacing.s\n          : `${theme.variables.size.spacing.s} ${theme.variables.size.spacing.l}`,\n      }),\n\n      ...(iconOnly &&\n        size === \"l\" && {\n          padding: theme.variables.size.spacing.m,\n        }),\n\n      ...(!checked &&\n        !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      \"input:focus-visible + &\": {\n        outlineWidth: \"2px\",\n        outlineStyle: \"solid\",\n        outlineColor: \"Highlight\",\n      },\n\n      \"@media (-webkit-min-device-pixel-ratio:0)\": {\n        \"input: focus-visible + &\": {\n          outlineColor: \"-webkit-focus-ring-color\",\n          outlineStyle: \"auto\",\n        },\n      },\n    };\n\n    if (!isResponsive) {\n      return {\n        ...baseStyle,\n        ...borderStyle,\n      };\n    }\n\n    return {\n      ...baseStyle,\n\n      // Layout tablet and desktop\n      [`@media (min-width: ${breakpoints.medium.value}px)`]: {\n        ...borderStyle,\n      },\n\n      // Layout mobile\n      [`@media (max-width: ${breakpoints.medium.value}px)`]: {\n        flexDirection: \"row\",\n        justifyContent:\n          sublabel || displayAsOptionWithSublabel ? \"space-between\" : \"center\",\n        padding: theme.variables.size.spacing.m,\n        borderTopStyle: \"none\" as const,\n        borderBottomStyle: \"none\" as const,\n        borderLeftStyle: \"solid\" as const,\n        borderRightStyle: \"solid\" as const,\n\n        \"&:first-of-type\": {\n          borderTopLeftRadius: theme.variables.size.borderRadius.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  size,\n  disabled = false,\n  isResponsive = false,\n  displayAsOptionWithSublabel = false,\n  onChange,\n  onClick,\n  onBlur,\n  onFocus,\n}: SegmentedControlOptionProps): React.ReactElement {\n  const labelSize = size === \"l\" ? \"m\" : \"s\";\n  const containerRef = useRef();\n  const iconElm = iconName ? (\n    <StyledIconContainer>\n      <Icon name={iconName} size=\"s\" />\n    </StyledIconContainer>\n  ) : null;\n  const showIcon = !sublabel && iconElm;\n  const labelElm = (\n    <StyledLabel size={labelSize} weight=\"bold\">\n      {label}\n    </StyledLabel>\n  );\n  let labelContainerElm = labelElm;\n\n  if (showIcon) {\n    if (!iconOnly) {\n      // label with icon\n      labelContainerElm = (\n        <Inline space=\"s\" noWrap vAlignItems=\"center\">\n          {iconElm}\n          {labelElm}\n        </Inline>\n      );\n    } else {\n      // icon with hidden label\n      labelContainerElm = (\n        <>\n          {iconElm}\n          <ScreenReaderText>{label}</ScreenReaderText>\n        </>\n      );\n    }\n  }\n\n  const sublabelElm = sublabel ? (\n    <StyledSublabel size=\"s\" isResponsive={isResponsive}>\n      {sublabel}\n    </StyledSublabel>\n  ) : null;\n  const showTooltip = 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      >\n        <StyledInput\n          type=\"radio\"\n          name={name}\n          value={value}\n          checked={checked}\n          disabled={disabled}\n          onChange={onChange}\n          onClick={onClick}\n          onBlur={onBlur}\n          onFocus={onFocus}\n        />\n        {labelContainerElm}\n        {sublabelElm}\n      </StyledContainer>\n      {showTooltip && (\n        <Tooltip content={tooltipContent} externalTriggerRef={containerRef} />\n      )}\n    </>\n  );\n}\n"],"names":[],"mappings":"AA8DwB"} */");export function SegmentedControlOption({name,value="",checked,label="",sublabel,iconName,iconOnly,tooltipContent,size,disabled=!1,isResponsive=!1,displayAsOptionWithSublabel=!1,onChange,onClick,onBlur,onFocus}){let containerRef=useRef(),iconElm=iconName?/*#__PURE__*/React.createElement(StyledIconContainer,null,/*#__PURE__*/React.createElement(Icon,{name:iconName,size:"s"})):null,showIcon=!sublabel&&iconElm,labelElm=/*#__PURE__*/React.createElement(StyledLabel,{size:"l"===size?"m":"s",weight:"bold"},label),labelContainerElm=labelElm;showIcon&&(labelContainerElm=iconOnly?/*#__PURE__*/React.createElement(React.Fragment,null,iconElm,/*#__PURE__*/React.createElement(ScreenReaderText,null,label)):/*#__PURE__*/React.createElement(Inline,{space:"s",noWrap:!0,vAlignItems:"center"},iconElm,labelElm));let sublabelElm=sublabel?/*#__PURE__*/React.createElement(StyledSublabel,{size:"s",isResponsive:isResponsive},sublabel):null;return /*#__PURE__*/React.createElement(React.Fragment,null,/*#__PURE__*/React.createElement(StyledContainer,{size:size,checked:checked,sublabel:sublabel,iconOnly:iconOnly,isResponsive:isResponsive,displayAsOptionWithSublabel:displayAsOptionWithSublabel,ref:containerRef,disabled:disabled},/*#__PURE__*/React.createElement(StyledInput,{type:"radio",name:name,value:value,checked:checked,disabled:disabled,onChange:onChange,onClick:onClick,onBlur:onBlur,onFocus:onFocus}),labelContainerElm,sublabelElm),!!tooltipContent&&/*#__PURE__*/React.createElement(Tooltip,{content:tooltipContent,externalTriggerRef:containerRef}))}
@@ -7,4 +7,4 @@ export type SelectProps = {
7
7
  onFocus?: FocusEventHandler<HTMLButtonElement>;
8
8
  onBlur?: FocusEventHandler<HTMLButtonElement>;
9
9
  } & Omit<SelectWithCustomTriggerProps, "renderTrigger"> & FormFieldProps;
10
- export declare function Select({ options, name, value, placeholder, hasError, optionsListWidth, maxHeight, disabled, portalContainer, readOnly, label, labelHint, hideLabel, hint, errorMessages, "data-e2e-test-id": dataE2eTestId, onChange, onFocus, onBlur, }: SelectProps): ReactElement;
10
+ export declare function Select({ options, name, value, placeholder, hasError, optionsListWidth, maxHeight, disabled, portalContainer, readOnly, label, labelHint, hideLabel, hint, errorMessages, size, "data-e2e-test-id": dataE2eTestId, onChange, onFocus, onBlur, }: SelectProps): ReactElement;